@font-face {
    font-family: Montserrat;
    font-weight: 700;
    font-style: normal;
    src: url("../font/montserrat/Montserrat-Bold.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 600;
    font-style: normal;
    src: url("../font/montserrat/Montserrat-SemiBold.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 500;
    font-style: normal;
    src: url("../font/montserrat/Montserrat-Medium.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 400;
    font-style: normal;
    src: url("../font/montserrat/Montserrat-Regular.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 300;
    font-style: normal;
    src: url("../font/montserrat/Montserrat-Light.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 700;
    font-style: italic;
    src: url("../font/montserrat/Montserrat-BoldItalic.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 600;
    font-style: italic;
    src: url("../font/montserrat/Montserrat-SemiBoldItalic.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 500;
    font-style: italic;
    src: url("../font/montserrat/Montserrat-MediumItalic.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 400;
    font-style: italic;
    src: url("../font/montserrat/Montserrat-Italic.otf") format("opentype");
}
@font-face {
    font-family: Montserrat;
    font-weight: 300;
    font-style: italic;
    src: url("../font/montserrat/Montserrat-LightItalic.otf") format("opentype");
}
html {
    font-family: sans-serif;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
}
body {
    margin: 0;
    font-size:14px;
    color:#4d4d4d;
    font-family:Montserrat, sans-serif;
    background:#fff;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
    display: block;
}
audio,
canvas,
progress,
video {
    display: inline-block;
    vertical-align: baseline;
}
audio:not([controls]) {
    display: none;
    height: 0;
}
[hidden],
template {
    display: none;
}
a {
    background-color: transparent;
}
abbr[title] {
    border-bottom: 1px dotted;
}
b,
strong {
    font-weight: bold;
}
dfn {
    font-style: italic;
}
mark {
    color: #000;
    background: #ff0;
}
small {
    font-size: 80%;
}
sub,
sup {
    position: relative;
    font-size: 75%;
    line-height: 0;
    vertical-align: baseline;
}
sup {
    top: -.5em;
}
sub {
    bottom: -.25em;
}
img {
    border: 0;
}
svg:not(:root) {
    overflow: hidden;
}
figure {
    margin: 1em 40px;
}
hr {
    height: 0;
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
}
pre {
    overflow: auto;
}
code,
kbd,
pre,
samp {
    font-family: monospace, monospace;
    font-size: 1em;
}
button,
input,
optgroup,
select,
textarea {
    margin: 0;
    font: inherit;
    color: inherit;
}
button {
    overflow: visible;
}
button,
select {
    text-transform: none;
}
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
    -webkit-appearance: button;
    cursor: pointer;
}
button[disabled],
html input[disabled] {
    cursor: default;
}
button::-moz-focus-inner,
input::-moz-focus-inner {
    padding: 0;
    border: 0;
}
input {
    line-height: normal;
}
input[type="checkbox"],
input[type="radio"] {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0;
}
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    height: auto;
}
input[type="search"] {
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
    -webkit-appearance: textfield;
}
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}
fieldset {
    padding: .35em .625em .75em;
    margin: 0 2px;
    border: 1px solid #c0c0c0;
}
legend {
    padding: 0;
    border: 0;
}
textarea {
    overflow: auto;
}
optgroup {
    font-weight: bold;
}
table {
    border-spacing: 0;
    border-collapse: collapse;
}
td,
th {
    padding: 0;
}
* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    margin:0;
}
*:before,
*:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
a {
    text-decoration: none;
}
ul {
    list-style:none;
}
p {
    margin-bottom:10px;
}
.sticky-wrapper {
    height:auto!important;
}
.sticky-wrapper > header {
    z-index:99!important;
}
.sticky-wrapper.is-sticky > header {
    box-shadow:0 0 10px #999;
}

body > header {
    position: fixed;
    z-index: 99;
    top:0;
    left:0;
    width:100%;
}
body > header.scrolling {
    box-shadow:0 0 10px #999;
}
body {
    margin-top:60px;
}
.mfp-wrap figure {
    margin:0;
}
.img-responsive {
    max-width:100%;
}
.text-center {
    text-align:center;
}
#top {
    padding:25px 90px 0;
    display:flex;
    flex-direction:row;
    flex-wrap:nowrap;
    justify-content:space-between;
    background:#fff;
    position:relative;
}
body > header.scrolling #top .menu > ul > li {
    padding-top:25px;
}
body > header.scrolling #logo img {
    padding-bottom:3px!important;
}
#top .header-search > div {
    position:relative;
    display:inline-block;
    padding-bottom:15px;
}
#top .header-search input {
    background:#F2F2F2;
    font-size:15px;
    line-height:27px;
    border:none;
    border-radius:15px;
    padding:0 30px 0 15px;
    width:140px;
    height:27px;
}
#top .header-search button {
    position:absolute;
    z-index:1;
    top:5px;
    right:7px;
    background:none;
    border:none;
}
#top .header-search button img {
    width:15px;
    height:15px;
}
#top .menu {
    margin-right:15px;
}
#top .menu > ul {
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    flex-direction:row;
    flex-wrap:wrap;
}
#top .menu > ul > li {
    padding-top:48px;
}
#top .menu > ul > li > a {
    font-size: 15px;
    font-weight:700;
    color: #1a4965;
    margin-left: 10px;
    margin-right: 10px;
    position: relative;
    padding-bottom: 15px;
    display: inline-block;
    text-transform:uppercase;
}
#top .menu > ul > li > a:hover {
    color:#7EBDB2;
}
#top .menu > ul > li > a::after {
    content:'';
    display:table;
    position:absolute;
    z-index:1;
    right:-15px;
    top:4px;
    height:16px;
    border-right:solid 1px #D7D8D8;
}
#top .menu > ul > li:first-child > a {
    margin-left:0;
}
#top .menu > ul > li:last-child > a {
    margin-right:0;
}
#top .menu > ul > li:last-child > a::after {
    display:none;
}
#top > div {
    display:flex;
    align-items:flex-end;
}
#top .menu ul > li > div {
    position:absolute;
    z-index:10;
    top:calc(100% - 1px);
    left:0;
    width:100%;
    padding:60px 40px 40px;
    background:#1a4965;
    border-bottom:solid 1px #fff;
}
#top .menu ul > li > div > ul {
    margin:0;
    padding:0;
    display:flex;
    flex-direction:column;
    flex-wrap:wrap;
    width:1200px;
    align-items: center;
    font-size:12px;
}
#top .menu ul > li > div > ul[data-width="1200"] {
    margin:0 auto!important;
}
#top .menu ul > li > div > ul > li {
    width:200px;
}
#top .menu ul > li > div > ul > li li a {
    color:#fff;
    line-height:20px;
}
#top .menu ul > li > div > ul > li > a {
    color:#76D6DC;
    font-weight:700;
    line-height:35px;
    font-size:15px;
}
#top .menu a:hover {
    text-decoration:underline;
}
#top li.active > a::before {
    content: '';
    position: absolute;
    z-index:11;
    left: calc(50% - 15px);
    bottom: -29px;
    border: 15px solid transparent;
    border-top: 15px solid #fff;
}

.container, .container-small {
    width:calc(100% - 30px);
    margin-left:auto;
    margin-right:auto;
}
h1.title-left {
    font-size:23px;
    margin:20px 0 20px;
}
h1, h2 {
    font-size:23px;
}
h2.title-left, h2.title-center, h2.title-right {
    font-size:23px;
    margin:30px 0 40px;
}
.title-left strong, .title-center strong, .title-right strong, .product-title strong {
    display:block;
}
.title-center {
    text-align:center;
}
.title-left, .title-center, .title-right {
    overflow:hidden;
}
.title-left span.no-line::after, .title-center span.no-line::before, .title-center span.no-line::after {
    display:none;
}
.title-center span {
    display:inline-block;
    padding:0 25px;
    position:relative;
    top:3px;
}
.title-center span::before, .title-center span::after {
    content:'';
    display:table;
    height:3px;
    bottom:5px;
    background:#1a4965;
    width:100vw;
    position:absolute;
    z-index:1;
}
.title-center span::before {
    right:100%;
}
.title-center span::after {
    left:100%;
}
.title-black {
    color:rgb(12,33,52)!important;
}
.title-black span::before, .title-black span::after {
    background:rgb(12,33,52)!important;
}
.title-blue {
    color:rgb(25,73,101)!important;
}
.title-blue span::before, .title-blue span::after {
    background:rgb(25,73,101)!important;
}
.title-green {
    color:rgb(87,169,167)!important;
}
.title-green span::before, .title-green span::after {
    background:rgb(87,169,167)!important;
}
.title-green2 {
    color:rgb(107,200,192)!important;
}
.title-green2 span::before, .title-green2 span::after {
    background:rgb(107,200,192)!important;
}
.title-grey {
    color:rgb(167,169,172)!important;
}
.title-grey span::before, .title-grey span::after {
    background:rgb(167,169,172)!important;
}

.home-top-section {
    position:relative;
}
.home-top-section > div:first-child {
    max-width:100%;
}
section p.strong {
    font-size:15px;
    font-weight:600;
    margin:22px 0 10px;
}
.home-top-section p {
    margin-bottom:10px;
    line-height:1.2;
}
.home-top-section > div:nth-child(2) {
    text-align:center;
    margin-top:15px;
}
.home-top-section > div:nth-child(2) img {
    width: 300px;
    max-width:100%;
}
.home-top-section.home {
    min-height:auto;
}

.home-second-section {
    padding:10px 15px;
    display:block;
}
.home-second-section ul {
    list-style:none;
    padding:0;
}
.home-second-section li {
    padding-left:30px;
    position:relative;
    line-height:1.2;
    padding-bottom:10px;
}
.home-second-section li::before {
    content:'';
    display:table;
    position:absolute;
    z-index:1;
    left:0;
    top:calc(50% - 6px);
    height:4px;
    width:4px;
    border-radius:2px;
    background:#6bc6bf;
}

.white-grad {
    margin-bottom:10px;
}
.home-wokrs-with ul {
    list-style:none;
    padding:0;
    display:flex;
    flex-wrap:wrap;
}
.home-wokrs-with {
    margin-bottom:0;
    padding-bottom:0;
}
.home-wokrs-with ul li {
    text-align:center;
    width:100%;
    height:70px;
    display:flex;
}
.home-wokrs-with ul li span {
    width:100%;
    align-self:center;
}
.home-wokrs-with img {
    vertical-align:top;
}
.home-wokrs-with .visible-xs img {
    margin:0 20px;
}
.home-cols {
    display:flex;
    flex-wrap:wrap;
    margin-top:30px;
    margin-bottom:15px;
    justify-content:center;
}
.home-cols > div {
    width:250px;
    margin-left:7.5px;
    margin-right:7.5px;
    max-width:300px;
}
.home-cols > div > div {
    margin:0 5px 25px;
    background:#1a4965;
    height:290px;
    border-radius:5px;
    color:#fff;
    padding:15px;
    position:relative;
    cursor:pointer;
    transition:all 0.2s ease-in-out 0.2s;
}
.home-cols > div:nth-child(even) > div {
    background:#58a7a6;
}
.home-cols > div > div:hover {
    background:#58a7a6!important;
}
.home-cols > div > div h5 {
    text-align:center;
    font-size:26px;
    font-weight:700;
    margin:10px 0 15px;
}
.home-cols > div > div p {
    line-height:20px;
    font-size:16px;
    font-weight:600;
}
.home-cols > div > div span {
    font-size:15px;
    position:absolute;
    z-index:1;
    display:block;
    color:#1a4965;
    background:#fff;
    left:0;
    bottom:30px;
    width:70%;
    text-align:center;
    text-transform:uppercase;
    line-height:53px;
    border-top-right-radius:30px;
    border-bottom-right-radius:30px;
}

#footer {
    position:relative;
    overflow:hidden;
}
#footer .copy {
    text-align:center;
    line-height:40px;
    color:#666666;
}
#footer > div:first-child {
    height:auto;
    background:#1a4965;
    color:#ffffff;
}
#footer > div:first-child > div {
    position:relative;
    z-index:2;
}
#footer .footer {
    display:flex;
    flex-direction:column-reverse;
    flex-wrap:nowrap;
    align-items:center;
}
#footer .footer > div {
    display:flex;
}
#footer .footer > div > div {
    align-self: center;
    padding:17px 0;
}
.social img {
    width:32px;
    display:block;
    margin:0 10px;
}
.social a .social-active {
    display:none;
}
.social {
    display:flex;
    padding:10px 0;
}
#footer .footer > div > div p {
    text-align:center;
    font-size:13px;
}
.footer-links {
    display:flex;
    padding-bottom:5px;
}
.footer-links a {
    color:#fff;
    font-size:13px;
}
.footer-links a:hover {
    text-decoration:underline;
    color:#58a6a5;
}
.footer-links ul {
    list-style:none;
    padding:25px 0 0;
    width:auto;
}
.footer-links ul:first-of-type {
    padding-right:15px;
}
.footer-links li {
    position:relative;
    padding-left:15px;
    line-height:28px;
}
.footer-links li::before {
    content:'';
    display:table;
    position:absolute;
    z-index:1;
    left:0;
    top:calc(50% - 4px);
    background:#58a6a5;
    height:7px;
    width:7px;
    border-radius:4px;
}

.acp-bg section {
    position:relative;
    overflow:hidden;
}
.acp-bg {
    position:relative;
    overflow: hidden;

    background-image:url('../image/acp-logo-page.svg');
    background-repeat:no-repeat;
    background-size: 140%;
    background-position: 140% 200px;
}
.white-grad {
    background: linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0, 0.02) 100%);
}

#top-mob {
    height:60px;
    padding:5px 17px;
    display:flex;
    flex-wrap:nowrap;
    align-items:center;
    justify-content:space-between;
    background:#d9e1e6;
}
#top-mob.active-menu {
    background:#e9eef0;
}
#top-mob.active-search {
    background: #fff;
    padding-left:10px;
    justify-content:flex-end;
}

#top-mob #logo-mob img {
    height:35px;
    width:150px;
}

#top-mob .icon-search, #top-mob .icon-menu {
    display:inline-block;
    height:19px;
    width:30px;
    background-repeat:no-repeat;
    background-position:center center;
    cursor:pointer;
    margin-top:4px;
}

#top-mob .icon-search {
    background-image:url('../image/icon-zoom-mobile.svg');
    margin-right:5px;
}
#top-mob .icon-menu {
    background-image:url('../image/icon-nav-mobile.svg');
}
#top-mob .icon-menu.active {
    background-image:url('../image/icon-nav-close-mobile.svg');
}
#menu-mob {
    position:absolute;
    z-index:20;
    top:60px;
    left:0;
    width:100%;
    height:calc(100vh - 60px);
    background:rgba(26, 73, 101, 0.95);
    overflow-y:auto;
    overflow-x:hidden;
    color:#fff;
}
#menu-mob ul {
    list-style:none;
    padding:15px 30px;
}
#menu-mob div ul {
    padding:15px 0;
}
#menu-mob  ul a {
    color:#fff;
    font-size:23px;
}
#menu-mob  ul > li > a {
    line-height:40px;
    display:block;
}
#menu-mob > ul > li {
    position:relative;
}
#menu-mob > ul > .has-children::after {
    position:absolute;
    z-index:1;
    bottom:calc(50% - 9px);
    right:0;
    content:'';
    display:table;
    width:6px;
    height:18px;
    background:url('../image/left-menu.png');
    background-size:contain;
}

#menu-mob > div {
    padding:0 30px;
}
#menu-mob > div > div {
    border-bottom:solid 3px #6a889b;
    height:70px;
    display:flex;
    justify-content:space-between;
    align-items: center;
    font-size:18px;
}
#menu-mob > div > div a {
    color:#6a889b;
    font-weight:500;
}
#menu-mob > div > div span {
    position:relative;
    padding-left:20px;
    font-weight:500;
    cursor:pointer;
}
#menu-mob > div > div span::before {
    content:'';
    display:table;
    position:absolute;
    z-index:1;
    left:0;
    bottom:2px;
    height:18px;
    width:6px;
    background:url('../image/right-menu.png');
    background-size:contain;
}
body.active-menu {
    overflow:hidden;
    height:100vh;
}
#search-mob {
    max-width:calc(100% - 80px);
    width:300px;
}
#search-mob input {
    background:#f1f1f1;
    border:solid 2px #dfdfdf;
    line-height:32px;
    border-radius:5px;
    width:calc(100% - 10px);
    padding:0 10px;
    font-size:18px;
}
#search-mob button {
    display:none;
}
.current-page {
    color:#a7a9ac!important;
}

.top-slide {
    min-height: calc(100vh - 60px);
    height: calc(100vh - 60px);
    width: 100%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    color:#fff;
}
.top-slide  * {
    color:#fff;
}
.swiper-slide {
    position:relative;
    background:rgba(26, 73, 101, 1);
}
.swiper-slide > span {
    position: absolute;
    z-index:1;
    content:'';
    display:table;
    width:100%;
    top:0;
    left:0;
    background-size:cover;
    opacity:0.45;
    height: calc(100vh - 60px);
    background-repeat: no-repeat;
    background-position: center center;
}
.swiper-slide > div {
    position:relative;
    z-index:2;
}
.swiper-slide > div .main-banner {
    width:100%;
    padding:85px 20px 0;
    color:#fff;
    position: relative;
    z-index: 3;
}
.swiper-slide > div .main-banner.products {
    align-self:normal;
    padding-top:85px;
}
.swiper-slide > div .main-banner > span {
    display:inline-block;
    border-bottom: solid 2px #93D5D9;
    padding-bottom:10px;
    font-size:24px;
    font-weight:700;
}
.swiper-slide > div .main-banner > div {
    margin-top:12px;
}
.swiper-slide > div .main-banner .strong-bg {
    color:#000;
    background:rgba(223,223,223,0.85);
    padding:0 10px;
}
.arrow-down {
    position:relative;
}
.arrow-down::after {
    content:'';
    display:table;
    position:absolute;
    z-index:1;
    bottom:80px;
    left:calc(50% - 22px);
    height:13px;
    width:45px;
    background:url('../image/down.png');
    background-size:contain;
}

.img-cols {
    display:block;
    max-width:100%;
    margin:25px auto 15px;
}
.img-cols > div {
    padding:0 5px 5px;
    max-width:491px;
}
.img-cols img {
    max-width:100%;
    display:block;
    opacity:0.2;
}
.img-cols > div > a {
    position:relative;
    display:block;
    overflow:hidden;
    border-radius:15px;
}
.img-cols > div > a::after {
    content:'';
    display:table;
    position:absolute;
    z-index:-1;
    width:100%;
    height:100vh;
    top:0;
    left:0;
    background:#1a4965;
}
.img-cols > div > a:hover::after {
    background:#58a7a6;
}
.img-cols > div > a > span {
    position:absolute;
    z-index:2;
    top:0;
    left:0;
    width:100%;
    display:block;
}
.img-cols > div > a > span span {
    display:block;
    font-size:24px;
    font-weight:700;
    padding:50px 55px;
    color:#fff;
}
.img-cols.capability > div > a > span span {
    padding:20px 20px 0;
}
.img-cols.capability > div p {
    padding:10px 10px 0;
}
.contact-btn {
    display:block;
    color:#fff;
    font-weight:700;
    background:#58a7a6;
    text-align:center;
    padding:10px;
    border-radius:20px;
    margin-top:25px;
}
.contact-btn:hover {
    background:#1a4965;
}
.categories {
    display:flex;
    flex-wrap:wrap;
    padding:15px 0;
    justify-content:center;
}
.categories > div {
    width:300px;
}
.categories > div a {
    display:block;
    background:rgba(211,212,214,0.65);
    margin:0 5px 35px;
    border-radius:10px;
}
.categories > div a:hover {
    background:rgba(182,227,223,0.8);
}
.categories > div img {
    max-width:100%;
    padding:0 12%;
}
.categories > div span {
    display:block;
    padding:28px 20px 8px;
    font-size:18px;
    color:#1a4965;
    font-weight:700;
    line-height:34px;
    box-sizing: content-box;
    text-align:center;
}
.categories > div em {
    font-style:normal;
    color:#6bc7bf;
    font-size:16px;
    font-weight:700;
    display:block;
    padding:5px 25px 30px;
}
.subcategories {
    display:flex;
    flex-wrap:wrap;
    margin:0 0 40px;
}
.subcategories > div {
    width:100%;
    padding:23px 5px;
}
.subcategories > div > a {
    display:flex;
    flex-wrap:nowrap;
    width:100%;
    background:rgba(211,212,214,0.65);
    border-radius:15px;
}
.subcategories > div a:hover {
    background:rgba(182,227,223,0.8);
}
.subcategories > div > a > span {
    width:50%;
}
.subcategories > div > a > span:first-child {
    position:relative;
}
.subcategories > div > a > span:last-child {
    text-align:right;
}
.subcategories > div > a > span span {
    font-size:18px;
    font-weight:700;
    color:#1a4965;
    display:block;
    padding:20px 10px 10px 10px;
}
.subcategories > div > a > span em {
    position:absolute;
    z-index:1;
    bottom:20px;
    left:10px;
    color:#6bc7bf;
    font-size:14px;
    font-weight:bold;
    font-style:normal;
}
.subcategories img {
    max-width:100%;
}

.breadcrumb {
    padding:10px 0 0;
    list-style:none;
    display:flex;
    flex-wrap:wrap;
    font-size:12px;
    margin:25px 0 0;
}
.breadcrumb li {
    position:relative;
    padding-right:20px;
    padding-top:0;
}
.breadcrumb li::after {
    content:'';
    position:absolute;
    z-index:1;
    bottom:2px;
    right:5px;
    text-align:center;
    width:9px;
    height:10px;
    color:#a7a9ac;
    background:url('../image/breadcrumb.png');
    background-size:contain;
    background-repeat:no-repeat;
}
.breadcrumb li:last-child::after {
    display:none;
}
.breadcrumb li:last-child {
    padding-right:0;
}
.breadcrumb a {
    text-decoration:none;
    color:#1a4965;
}
.breadcrumb span {
    color:#a7a9ac;
}

.category-details {
    display:block;
    margin-bottom:20px;
}
.category-details > div:first-child {
    padding-right:0;
}
.category-details p {
    margin-bottom:10px;
    line-height:1.6;
}
.category-details img {
    max-width:300px;
}

.products-filters {
    display:block;
}
.products-filters > div {
    margin-bottom:15px;
    display:inline-block;
}
.products-filters > div:first-child > div {
    display:flex;
}
.products-filters > div:first-child > div button {
    width:46px;
    height:46px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0;
    border-radius:0;
    font-size:24px;
    color:#777;
    background:#e9e9e9;
    border:solid 1px #e1e1e1;
}
.products-filters > div:first-child > div button.active {
    color:#333;
    background:#d9dbdb;
    border:solid 1px #c4c6c6;
}
.products-filters > div:last-child > div {
    font-size:14px;
    line-height:42px;
    display:flex;
    border:solid 2px #e9e9e9;
    position:relative;
}
.products-filters > div:last-child > div label {
    background:#e9e9e9;
    padding:0 14px;
}
.products-filters > div:last-child > div select {
    background:transparent;
    border:none;
    border-radius:0;
    width:140px;
    padding:0 35px 0 5px;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    -ms-appearance:none;
}
.products-filters > div:last-child > div select::-ms-expand{
    display: none;
}
.products-filters > div:last-child > div::after {
    content:'';
    display:table;
    right:18px;
    top:calc(50% - 3px);
    height:9px;
    width:15px;
    background:url('../image/select-down.png');
    background-size:contain;
    position:absolute;
    z-index:-1;
}
.products-filters > div:last-child > div::before {
    content:'';
    display:table;
    right:0;
    top:0;
    height:60px;
    width:100%;
    position:absolute;
    z-index:-2;
    background:#fff;
    opacity:0.8;
}

.products-catalog {
    display:flex;
    flex-wrap:wrap;
    margin:0 -8px;
}
.products-catalog > div {
    width:calc(50% - 16px);
    border:solid 1px #ececec;
    margin-bottom:20px;
    background:rgba(255,255,255,0.8);
    position:relative;
    margin-left:8px;
    margin-right:8px;
}
.products-catalog > div .image {
    text-align:center;
}
.products-catalog > div h4 {
    font-size:12px;
    font-weight:600;
    line-height:15px;
    padding:0 13px 13px;
    margin-bottom:0;
}
.products-catalog > div h4 a {
    color:#1a4965;
}
.products-catalog > div p {
    font-size:14px;
    line-height:22px;
    padding:0 20px;
}
.products-catalog > div .info > a {
    position:absolute;
    right:0;
    bottom:0;
    z-index:1;
    font-size:12px;
    font-weight:700;
    color:#6bc7bf;
    text-align:center;
    width:100%;
    background:#eaeaea;
    display:block;
    line-height:59px;
}
.products-catalog > div .info > a:hover {
    background:#c6e9e5;
}

.banner-text {
    display:flex;
    align-items: center;
    color:#fff;
    position: relative;
    z-index: 3;
    width:100%;
}
.banner-text .container > div {
    width:750px;
    max-width:100%;
}
.banner-text h1, .banner-text h2 {
    border-bottom:solid 4px #c6e9e5;
    padding-bottom:15px;
    margin-bottom:20px;
    color:#fff;
}
.bottom-p {
    margin-bottom:10px;
}
strong.container-small {
    display:block;
}
h1,h2,h3 {
    color:#1a4965;
}
h3 {
    font-weight:700;
    font-size:18px;
    margin:10px 0;
}
h3.title-left {
    text-align:right;
}
h3.title-right span {
    position:relative;
}
h3.title-right span::before {
    content:'';
    display:table;
    background:#1a4965;
    width: 100vw;
    position: absolute;
    z-index: 1;
    height: 3px;
    bottom: 5px;
    right: calc(100% + 25px);
}
h3.title-left span {
    padding:0;
    color:#6bc7bf;
    position:relative;
}
h3.title-left span::after {
    content:'';
    display:table;
    background:#6bc7bf;
    width: 100vw;
    position: absolute;
    z-index: 1;
    height: 3px;
    bottom: 5px;
    left: calc(100% + 25px);
}
h1.product-title {
    font-size:18px;
    margin:10px 0;
}
h1.product-title span {
    position:relative;
    display:inline-block;
}
h1.product-title span::after {
    content:'';
    display:table;
    background:#1a4965;
    width: 100vw;
    position: absolute;
    z-index: 1;
    height: 3px;
    bottom: 6px;
    left: calc(100% + 20px);
}
.symbol-top {
    position:relative;
    font-size:0.6em;
    bottom:0.6em;
}
.timeline-wrap {
    text-align:center;
}
.timeline {
    display:inline-flex;
    flex-wrap:nowrap;
    flex-direction:column-reverse;
    margin:10px 0 0 25px;
    border-left:solid 2px #93D5D9;
    position:relative;
    font-size:16px;
    text-align:left;
    width:300px;
    max-width:100%;
}
.timeline::after {
    content:'';
    display:table;
    position:absolute;
    z-index: 1;
    background:#fff;
    left:-2px;
    bottom:0;
    width:2px;
    height:30px;
}
.timeline strong {
    font-weight:600;
}
.timeline > div {
    height:auto;
    position:relative;
}
.timeline > div::before {
    content:'';
    display:table;
    position:absolute;
    z-index:2;
    width:24px;
    height:24px;
    border-radius:12px;
    background: #164965;
    left:-12px;
    top:-12px;
}
.timeline > div::after {
    content:'';
    display:table;
    position:absolute;
    z-index:1;
    width:40px;
    height:40px;
    border-radius:20px;
    background: rgba(107,199,191,0.5);
    left:-20px;
    top:-20px;
    box-shadow:0 0 0 5px rgba(107,199,191,0.25);
}
.timeline > div > div {
    padding:0 40px 20px;
    position: relative;
    top: -20px;
}
.timeline > div:last-child div {
    padding-bottom:0;
}
.map {
    text-align:center;
    color:#fff;
    background:#1a4965;
    font-size:16px;
    padding:35px 0 30px;
    margin-top:100px;
}
.map > div {
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
}
.map > div > div {
    width:145px;
    padding:20px 5px 5px;
}
.map > div > div img {
    max-width:100%;
    padding-bottom:15px;
}
.product-top {
    display:block;
}
.product-left {
    max-width:505px;
}
.product-left img {
    max-width:100%;
}
.product-right {
    padding:0;
}
.product-right, .product-left {
    width:100%;
    margin-bottom:20px;
}
.thumbnail > img {
     border:solid 1px #f1f1f1;
    box-shadow:0 0 0 1px #f9f9f9;
    background:rgba(255,255,255,0.8);
}
.thumbnail {
    color:#999;
}
.thumbnail.active > img {
    border-color:#999;
}
.thumbnail > img:hover {
    border-color:#6bc7bf;
}
.thumbnails > div {
    display:flex;
    flex-wrap:wrap;
}
.thumbnails > div:last-child {
    margin:0 -10px;
}
.thumbnails > div:last-child > * {
    margin:15px 11px 0;
}
.thumbnails > div:last-child img {
    width:100px;
}
@media(max-width:450px) {
    .thumbnails > div:last-child > * {
        width:calc(33% - 22px);
    }
    .thumbnails > div:last-child img {
        width:100%;
    }
}

.download-wrap {
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    margin-top:30px;
}
.download-wrap > div {
    padding-left:30px;
}
.downloads {
    color:#4d4d4d;
}
.downloads > span {
    display:flex;
    align-items:center;
}
.downloads > span > span:first-child {
    padding:0 30px 0 40px;
}
.downloads strong {
    color:#6bc7bf;
    font-size:18px;
}
.downloads > span > span > span {
    display: block;
}
.downloads:hover strong {
    text-decoration:underline;
}
.highligth {
    background:yellow;
}
.features {
    display:block;
}
.features > div {
    width:100%;
    margin-top:30px;
    padding-right:10px;
}
.features > div ul {
    list-style:none;
    margin:0;
    padding:0;
    color:#4d4d4d;
    line-height:1.6;
}
.features > div li {
    position:relative;
    padding-left: 18px;
}
.features > div li::before {
    content:'';
    display:table;
    position:absolute;
    z-index:1;
    left:0;
    top:calc(50% - 2px);
    width:4px;
    height:4px;
    border-radius:2px;
    background:#4d4d4d;
}
.features > div span {
    display:block;
    text-transform:uppercase;
    font-weight:600;
    margin-bottom:10px;
}
.footer .visible-md {
    position:static;
}
.faq {
    margin-bottom:50px;
}
.faq > div {
    margin-bottom:20px;
}
.faq .question {
    font-size:1.1em;
    font-weight:500;
}
.faq .question > span {
    display:inline-block;
    cursor:pointer;
    position:relative;
    padding-left:15px;
}
.faq .question > span > span {
    width:15px;
    display:inline-block;
    position:absolute;
    z-index:1;
    top:0;
    left:0;
}
.faq .answer {
    font-style:italic;
    display:none;
    margin-top:4px;
}
.faq .answer.active {
    display:block;
}
.text-danger, label > .required {
    color:#cc1111;
}

.form > div {
    display:flex;
    flex-wrap:wrap;
    margin-bottom:15px;
}
.form > div > label {
    width:100%;
    font-size:0.9em;
    font-weight:600;
    margin-bottom:5px;
}
.form > div > div {
    width:100%;
}
.form > div input, .form > div textarea, .form > div select {
    width:100%;
    border-radius:0;
    border:solid 1px #4d4d4d;
    background:rgba(255,255,255,0.8);
    line-height:2;
    padding:0 10px;
}
.form > div input, .form > div select {
    height:38px;
}
.form > div input:focus, .form > div textarea:focus {
    border-color:#58a7a6;
}
.form .buttons {
    justify-content:right;
}
.form > div button {
    border:none;
    border-radius:0;
    background:#58a7a6;
    color:#fff;
    font-weight:700;
    padding:10px;
    text-align:center;
    width:150px;
}
.form > div button:hover {
    background:#1a4965;
}
.contact-box {
    display:block;
}
.contact-box > * {
    width:100%;
}
.contact-box h4 {
    margin-bottom:25px;
    font-size:1.2em;
}
#career-form form > * {
    display:block;
    vertical-align:middle;
    margin-bottom:5px;
}
#career-form form > * > * {
    display:block;
    vertical-align:middle;
}
#career-form div span {
    font-weight:600;
    margin-bottom:5px;
}
.select {
    position:relative;
    overflow:hidden;
    display:inline-block!important;
}
.select::before {
    content:'';
    display:table;
    position:absolute;
    background:rgba(0,0,0,0.4);
    top:0;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    height:42px;
    z-index:-2
}
.select::after {
    content: '';
    display: table;
    right: 18px;
    top: calc(50% - 3px);
    height: 9px;
    width: 15px;
    background: url('../image/select-down.png');
    background-size: contain;
    position: absolute;
    z-index: -1;
}
.select select {
    border:solid 2px #e9e9e9;
    border-radius:0;
    background:transparent;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    -ms-appearance:none;
    width: 247px;
    padding: 0 35px 0 18px;
    line-height:40px;
}
.select select::-ms-expand{
    display: none;
}
.select option {
    color:#4d4d4d!important;
}
#career-form button {
    background:#1a4965;
    border:solid 2px #e9e9e9;
    border-radius:0;
    line-height:42px;
    background:rgba(0,0,0,0.4);
    text-transform:uppercase;
    font-weight:600;
    text-align:center;
    width:160px;
}
.career-categories {
    display:flex;
    flex-wrap:wrap;
    margin: 0 -15px;
}
.career-categories > div {
    width: 100%;
    margin-left: 15px;
    margin-right: 15px;
    margin-bottom:20px;
    text-align:center;
}
.career-categories h4 {
    font-size:1.5em;
}
.career-categories a {
    color:#1a4965;
}
.career-categories em {
    color:rgb(107,200,192);
}

.career-positions.search-view-grid {
    display:flex;
    flex-wrap:wrap;
    margin: 0 -15px;
}
.career-positions.search-view-grid > div {
    margin-left:15px;
    margin-right:15px;
}

.career-positions > div {
    margin-bottom:20px;
    padding:15px;
    border:solid 1px #e9e9e9;
    background:rgba(255,255,255, 0.8);
}
.career-positions h4 {
    font-size:1.5em;
    margin:10px 0;
}
.career-positions a {
    color:#4d4d4d;
}
.career-description {
    margin-bottom:20px;
}
.career-description ul {
    list-style:unset;
}
.career-description > * {
    margin-bottom:20px;
}
.career-description h4 {
    font-size:1.5em;
}
.career-location {
    padding-bottom:15px;
    border-bottom:solid 2px #e9e9e9;
}

button.mfp-arrow {
    height: 70px !important;
    opacity:1;
    width:60px!important;
    top:calc(50% - 35px)!important;
    margin-top:0!important;
}
.mfp-arrow-left {
    background:rgba(0,0,0,0.4) url('/catalog/view/theme/acp/image/left.png') no-repeat 35% 50% !important;
    width: 50px;
    height: 50px;
    border-top-right-radius:35px;
    border-bottom-right-radius:35px;
}
.mfp-arrow-left:hover {
    background:rgba(0,0,0,0.4) url('/catalog/view/theme/acp/image/left-active.png') no-repeat 35% 50% !important;
}

.mfp-arrow-right {
    background:rgba(0,0,0,0.4) url('/catalog/view/theme/acp/image/right.png') no-repeat 65% 50% !important;
    width: 50px;
    height: 50px;
    border-top-left-radius:35px;
    border-bottom-left-radius:35px;
}
.mfp-arrow-right:hover {
    background:rgba(0,0,0,0.4) url('/catalog/view/theme/acp/image/right-active.png') no-repeat 65% 50% !important;
}

.mfp-arrow-left::before,
.mfp-arrow-right::before {
    display: none!important;
    content:'';
}

.mfp-arrow-left::after,
.mfp-arrow-right::after {
    display: none!important;
    content:'';
}

.tags a {
    color:#1a4965;
}

.product-product h3 {
    font-size:18px;
    font-weight:600;
    color:#4d4d4d;
    text-transform: uppercase;
    margin:30px 0;
}

.product-product table {
    width:100%;
    border:solid 1px #d7d7d7;
    border-collapse: collapse;
    background:#fff;
    margin:0;
}

.product-product table td, .product-product table th {
    border:solid 1px #d7d7d7;
    font-size:18px;
    padding:15px 30px;
}

.product-product thead td, .product-product thead th {
    background:#1a4965;
    color:#fff;
    font-weight:400;
}
.product-product tbody td, .product-product tbody th {
    font-weight:300;
    color:#4d4d4d;
}
.product-product tbody th {
    background:#fafafa;
}

.product-product tbody tr:hover td, .product-product tbody tr:hover th {
    background:#f3fcff;
}

.note {
    font-size:0.7em;
    color:#4d4d4d;
    font-weight:600;
    margin:-20px 0 30px;
}

.table-scroll {
    position:relative;
    max-width:100%;
    overflow:hidden;
    margin-bottom:40px;
}
.table-wrap {
    width:100%;
    overflow:auto;
}
.table-scroll table {
    width:100%;
}
.clone {
    position:absolute;
    top:0;
    left:0;
    pointer-events:none;
    background:transparent!important;
    border-color:transparent!important;
}
.clone td {
    visibility:hidden;
    background:transparent!important;
    border-color:transparent!important;
}
.clone .fixed-side {
    visibility:visible;
}

.product-image-slider-wrapper {
    padding:0 30px;
    position: relative;
    margin-top:15px;
}
.product-image-slider-wrapper .product-nav {
    border:none;
    background:none;
    padding:0;
    border-radius:0;
    position:absolute;
    z-index:1;
    top:50%;
    margin-top:-23px;
}
.product-image-slider-wrapper .product-nav-left {
    left:0;
}
.product-image-slider-wrapper .product-nav-right {
    right:0;
}
#product-image-slider .swiper-slide {
    background:none;
}
#product-image-slider .swiper-slide img {
    max-width:100%;
}

@media (min-width: 768px) {
    #career-form form > * {
        display:inline-block;
        margin-bottom:15px;
    }
    #career-form form > * > * {
        display:inline-block;
    }
    #career-form div span {
        margin:0;
    }
    .social a:hover .social-active {
        display:block;
    }
    .social a:hover .social-default {
        display:none;
    }
    .arrow-down::after {
        bottom:40px;
    }
    h3.title-right span::before {
        bottom: 7px;
        right: calc(100% + 30px);
    }
    h3.title-left span::after {
        bottom: 7px;
        left: calc(100% + 30px);
    }
    .products-filters {
        display:flex;
        flex-wrap:wrap;
        justify-content:space-between;
    }
    .products-catalog > div h4 {
        font-size:14px;
        line-height:17px;
        padding:0 20px 20px;
    }
    .products-catalog > div p {
        font-size:18px;
        line-height:28px;
    }
    .products-catalog > div .info > a {
        font-size:16px;
    }
    .products-filters > div:last-child > div {
        font-size:18px;
    }
    .products-filters > div:last-child > div select {
        width:247px;
        padding:0 35px 0 18px;
    }
    .products-catalog.product-view-list > div {
        width:100%;
        display:flex;
        min-height:120px;
    }
    .products-catalog.product-view-list > div .info > a {
        width:240px;
    }
    .products-catalog.product-view-list > div .image {
        padding:5px 30px 5px 10px;
        width:150px;
        line-height:48px;
        display:flex;
        align-items:center;
    }
    .products-catalog.product-view-list > div .image img {
        max-height:100%;
    }
    .products-catalog.product-view-list > div .info {
        width:calc(100% - 150px);
    }
    .products-catalog.product-view-list > div .info {
        padding:20px 250px 10px 0;
    }
    .products-catalog.product-view-list > div h4 {
        height: auto;
        margin-bottom:20px;
        font-size: 18px;
        line-height: 24px;
    }
    .products-catalog.product-view-list > div p {
        font-size: 16px;
        line-height: 24px;
    }
    .breadcrumb {
        font-size:14px;
        padding:0;
    }
    .breadcrumb li {
        padding-top:10px;
    }
    .breadcrumb a:hover {
        text-decoration:underline;
    }
    .category-details {
        display:flex;
        flex-wrap:nowrap;
        justify-content:space-between;
    }
    .category-details > div:first-child {
        padding-right:60px;
    }
    .subcategories > div {
        width:50%;
    }
    .swiper-slide > div .main-banner.products {
        align-self:center;
        padding-top:0;
    }
    .img-cols {
        display:flex;
        justify-content:center;
        width:100%;
        margin:25px auto 65px;
    }
    .img-cols > div > a > span span {
        font-size: 28px;
        padding:20px 55px;
    }
    .swiper-slide > div .main-banner {
        padding:25vh 20vw 0;
    }
    .swiper-slide > div .main-banner > span {
        border-bottom: solid 3px #93D5D9;
        padding-bottom:15px;
        font-size:36px;
    }
    .swiper-slide > div .main-banner > div {
        margin-top:18px;
    }
    .acp-bg {
        position:relative;
        overflow: hidden;

        background-image:url('../image/acp-logo-page.svg');
        background-repeat:no-repeat;
        background-size:100vw 1000px;
        background-position:-500px 330px;
    }
    .acp-bg section::after {
        display:none;
    }
    .visible-xs {
        display:none!important;
    }
    .hidden-xs {
        display:unset;
    }
    .container {
        width: 750px;
    }
    .container-small {
        width:640px;
    }
    h1.title-left, h2.title-left, h2.title-center, h2.title-right {
        font-size:36px;
        margin:20px 0 30px;
    }
    h1.product-title {
        font-size:24px;
        margin:20px 0;
    }
    h1, h2 {
        font-size:32px;
    }
    body {
        font-size:15px;
    }
    section p.strong {
        font-size:20px;
        margin:35px 0 20px;
    }
    .home-top-section p, .category-details p {
        margin-bottom:20px;
    }
    .home-top-section > div:first-child {
        max-width:620px;
    }
    .home-top-section > div:nth-child(2) {
        position:absolute;
        z-index:-1;
        top:-30px;
        right:0;
    }
    .home-top-section > div:nth-child(2) img {
        width: 300px;
    }
    .home-second-section {
        padding:15px 20px;
        display:flex;
    }
    .home-second-section.information {
        padding:0 0 30px;
    }
    .home-second-section > * {
        width:50%;
    }
    .home-top-section.about {
        min-height:200px;
    }
    .home-top-section.about > div:nth-child(2) {
        top:-100px;
    }
    .title-center span::before, .title-center span::after {
        bottom:10px;
    }
    .white-grad {
        margin-bottom:30px;
    }
    .home-wokrs-with {
        margin-bottom:0;
        padding:0;
    }
    .home-wokrs-with ul li {
        width:33%;
        height:160px;
    }
    .home-cols {
        margin-top:0;
        margin-bottom:35px;
    }
    .home-cols > div {
        width:50%;
        margin:0;
    }
    .home-cols > div > div {
        margin:0 5px 10px;
        background:#1a4965;
        border-radius:10px;
        padding:20px 24px;
    }
    .home-cols > div:nth-child(even) > div {
        background:#1a4965;
    }
    .home-cols > div > div h5 {
        font-size:30px;
        line-height:43px;
        margin:0 0 17px;
    }
    .home-cols > div > div span {
        font-size:inherit;
        width:75%;
        line-height:60px;
    }
    #footer .footer {
        display:flex;
        flex-direction:column-reverse;
        flex-wrap:wrap;
        justify-content: center;
    }
    #footer .copy {
        line-height:60px;
    }
    #footer .footer > div > div p {
        text-align:left;
        font-size:unset;
    }
    .social img {
        width:45px;
        display:block;
        margin: 0 20px 0 0;
    }
    .social {
        padding:15px 0;
    }
    .footer-links a {
        font-size:unset;
    }
    .footer-links li {
        position:relative;
        padding-left:20px;
        line-height:37px;
    }
    .footer-links ul {
        width:220px;
        padding:0;
    }
    .footer-links ul:first-of-type {
        padding-right:0;
    }
    .subcategories > div > a > span span {
        font-size: 21px;
        padding-top:40px;
        padding-left:20px;
    }
    .subcategories > div > a > span em {
        left:20px;
        font-size:16px;
    }
    .products-catalog > div {
        width:calc(33.3% - 16px);
    }
    .banner-text h1, .banner-text h2 {
        padding-bottom:25px;
        margin-bottom:30px;
    }
    .bottom-p {
        margin-bottom:15px;
    }
    h3 {
        font-size:24px;
        margin:20px 0 25px;
    }
    .timeline {
        font-size:18px;
    }
    .map {
        font-size:18px;
        padding:50px 0 30px;
        margin-top:100px;
    }
    .map > div > div {
        padding:5px;
        width:20%;
    }
    h1.product-title span::after {
        bottom: 7px;
        left: calc(100% + 30px);
    }
    .footer .visible-md {
        position:absolute;
        bottom:0;
        left:0;
    }
    .product-top {
        display:flex;
    }
    .product-right, .product-left {
        width:50%;
    }
    .product-right {
        padding:0 0 0 20px;
    }
    .downloads strong {
        font-size:21px;
    }
    .thumbnails > div:last-child img {
        width:auto;
    }
    .img-cols.capability {
        flex-wrap: wrap;
        justify-content: left;
    }
    .img-cols.capability > div {
        width:50%;
        padding-bottom:30px;
    }
    .img-cols.capability img {
        max-width:100%;
    }
    .img-cols.capability > div > a > span span {
        padding:20px 20px 0;
        font-size:28px;
    }
    .contact-btn {
        margin-top:85px;
    }
    .form > div {
        margin-bottom:20px;
    }
    .contact-box {
        display:flex;
    }
    .contact-box > * {
        width:50%;
    }
    .contact-box h4 {
        margin-bottom:40px;
    }
    .career-categories > div {
        width:calc(50% - 30px);
    }
    .banner-bottom {
        width:75%;
    }
    .breadcrumb li {
        padding-right:35px;
    }
    .breadcrumb li::after {
        bottom:3px;
        right:12px;
        width:9px;
        height:12px;
    }
    .home-top-section {
        min-height: 300px;
    }
    .career-positions.search-view-grid > div {
        width:calc(50% - 30px);
    }
}
@media (min-width: 992px) {
    body {
        margin-top:89px;
    }
    .home-top-section {
        min-height: 450px;
    }
    .img-cols > div > a > span span {
        font-size: 32px;
        padding:50px 55px;
    }
    h3.title-right span::before {
        bottom: 9px;
        right: calc(100% + 45px);
    }
    h3.title-left span::after {
        bottom: 9px;
        left: calc(100% + 45px);
    }
    .breadcrumb {
        font-size:16px;
    }
    .swiper-slide > div .main-banner > span {
        border-bottom: solid 4px #93D5D9;
        padding-bottom:25px;
        font-size:48px;
    }
    .swiper-slide > div .main-banner > div {
        margin-top:30px;
    }
    .swiper-slide > div .main-banner.products {
        padding-top:0;
    }
    .visible-md {
        display:none!important;
    }
    .container {
        width: 970px;
    }
    .container-small {
        width:750px;
    }
    body {
        font-size:18px;
    }
    h1, h2, h1.title-left, h2.title-left, h2.title-center, h2.title-right {
        font-size:48px;
    }
    h1.title-left span {
        padding-left:0;
    }
    h1.title-left {
        margin:20px 0 40px;
    }
    .title-left span, .title-right span {
        display:inline-block;
        padding:0 95px 0 85px;
        position:relative;
        top:3px;
    }
    .title-left.no-padding span, .title-right.no-padding span {
        padding:0;
    }
    .title-left span::after {
        content:'';
        display:table;
        height:3px;
        bottom:15px;
        left:100%;
        background:#1a4965;
        width:100vw;
        position:absolute;
        z-index:1;
    }
    .title-left.no-padding span::after {
        left:calc(100% + 60px);
    }
    .title-right span::before {
        content:'';
        display:table;
        height:3px;
        bottom:15px;
        right:100%;
        background:#1a4965;
        width:100vw;
        position:absolute;
        z-index:1;
    }
    .title-right.no-padding span::before {
        right:calc(100% + 60px);
    }
    h1.title-left span::after {
        background:#58a7a6;
    }
    h1.product-title {
        font-size:30px;
        margin:30px 0;
    }
    .title-center span {
        padding:0 130px;
    }
    .title-center span::before, .title-center span::after {
        bottom:15px;
    }
    h2 {
        margin:50px 0 25px;
    }
    section p.strong {
        font-size:26px;
        margin:50px 0 30px;
    }
    .home-top-section p, .category-details p {
        margin-bottom:35px;
    }
    .home-top-section.products p, .category-details p {
        margin-bottom:20px;
    }
    .home-top-section.information p.strong {
        line-height:1.4;
    }
    .home-top-section > div:first-child {
        max-width:720px;
    }
    .home-top-section > div:nth-child(2) {
        position:absolute;
        z-index:-1;
        top:-30px;
        right:0;
    }
    .home-top-section.information > div:nth-child(2) {
        top:0;
    }
    .home-top-section.products > div:nth-child(2) {
        top:10px;
    }
    .home-top-section.about {
        min-height:300px;
    }
    .home-top-section.about > div:nth-child(2) {
        top:-100px;
    }
    .home-top-section > div:nth-child(2) img {
        width: 420px;
    }
    .home-top-section.information > div:nth-child(2) img {
        width: 370px;
    }
    .home-second-section {
        padding:20px 120px;
    }
    .home-second-section.information {
        padding:0 20px 50px;
    }
    .white-grad {
        margin-bottom:50px;
    }
    .home-wokrs-with {
        margin-bottom:0;
    }
    .home-wokrs-with ul li {
        width:25%;
    }
    .home-cols {
        display:flex;
        margin-bottom:45px;
    }
    .home-cols > div {
        width:50%;
    }
    #footer .footer {
        display:flex;
        flex-direction:row;
        flex-wrap:nowrap;
        align-items: flex-end;
        justify-content: space-between;
        height:375px;
        padding:0;
    }
    #footer::after {
        content:'';
        display:table;
        position:absolute;
        z-index:1;
        background-image:url('../image/acp-logo-footer.svg');
        background-repeat:no-repeat;
        background-size:contain;
        top:40px;
        left:calc(50vw - 770px);
        height:530px;
        width:550px;
    }
    #footer .footer > div {
        display:block;
    }
    #footer .footer > div > div {
        padding:0;
    }
    #footer > div:first-child {
        height:450px;
    }
    #footer .copy {
        line-height:80px;
    }
    #top {
        padding:0 30px;
    }
    .top-slide, .top-slide > span {
        min-height: calc(100vh - 88px);
        height: calc(100vh - 88px);
    }
    .top-slide > span {
        height: calc(100vh - 88px);
    }
    .subcategories > div > a > span span {
        font-size: 27px;
        padding-top:60px;
        padding-left:30px;
    }
    .subcategories > div > a > span em {
        left:30px;
    }
    .products-catalog {
        margin-right:-15px;
        margin-left:-15px;
    }
    .products-catalog > div {
        width:calc(25% - 30px);
        margin-right:15px;
        margin-left:15px;
    }
    .banner-text h1, .banner-text h2 {
        padding-bottom:30px;
        margin-bottom:40px;
    }
    .bottom-p {
        margin-bottom:25px;
    }
    h3 {
        font-size:36px;
        margin:30px 0 40px;
    }
    .timeline-block {
        margin-top:50px;
    }
    .timeline {
        flex-direction:row;
        margin:50px 0 220px 20px;
        border-bottom:solid 2px #93D5D9;
        border-left:none;
        font-size:16px;
        width:auto;
    }
    .timeline::after {
        left:auto;
        right:0;
        bottom:-2px;
        height:2px;
        width:100px;
    }
    .timeline > div {
        height:150px;
        border-left:solid 1px #1a4965;
    }
    .timeline > div:nth-child(2n) {
        padding-top:60px;
        top:150px;
        position:absolute;
        z-index:1;
        height:auto;
    }
    .timeline > div:nth-child(2n)::before {
        bottom:auto;
        top:-12px;
    }
    .timeline > div:nth-child(2n)::after {
        bottom:auto;
        top:-20px;
    }
    .timeline > div::before {
        bottom:-12px;
        top:auto;
    }
    .timeline > div::after {
        bottom:-20px;
        top:auto;
    }
    .timeline > div > div {
        padding:0 10px;
        position:static;
    }
    .t-1995 {
        width:150px;
    }
    .t-1995 > div {
        width:150px
    }
    .t-1996 {
        left:60px;
    }
    .t-1996 > div {
        width:200px
    }
    .t-2001 {
        width:220px;
    }
    .t-2001 > div {
        width:220px
    }
    .t-2011 {
        left:260px;
    }
    .t-2011 > div {
        width:210px;
    }
    .t-2012 {
        width:220px;
    }
    .t-2012 > div {
        width:220px
    }
    .t-2014 {
        left:485px;
    }
    .t-2014 > div {
        width:210px;
    }
    .t-2015 {
        width:180px;
    }
    .t-2015 > div {
        width:180px;
    }
    .t-2018 {
        left:695px;
    }
    .t-2018 > div {
        width:230px;
    }
    .t-2019 {
        width:170px;
    }
    .map {
        font-size:21px;
        padding:70px 0 30px;
        margin-top:100px;
    }
    h1.product-title span::after {
        bottom: 9px;
    }
    .product-right {
        padding:0 0 0 25px;
    }
    .product-right, .product-left {
        width:auto;
    }
    .product-left img {
        max-width:unset;
    }
    .features {
        display:flex;
    }
    .features > div {
        margin-top:50px;
        width:50%;
    }
    .features > div span {
        margin-bottom:30px;
    }
    .download-wrap {
        margin-top:50px;
    }
    .downloads strong {
        font-size:24px;
    }
    .img-cols.capability > div {
        width:33.3%;
    }
    .contact-btn {
        margin-top:65px;
    }
    .career-categories > div {
        width:calc(33.3% - 30px);
    }
    .banner-bottom {
        width:50%;
    }
    .breadcrumb li::after {
        bottom:2px;
        height:16px;
    }
    #top .menu > ul > li {
        padding-top:52px;
    }
    .career-positions.search-view-grid > div {
        width:calc(33.33% - 30px);
    }
}

@media (min-width: 1300px) {
    h1.top-space {
        margin-top:160px;
    }

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

    h3.title-right span::before {
        bottom: 12px;
        right: calc(100% + 65px);
    }
    h3.title-left span::after {
        bottom: 12px;
        left: calc(100% + 65px);
    }
    .swiper-slide > div .main-banner > span {
        border-bottom: solid 4px #93D5D9;
        padding-bottom:35px;
        font-size:72px;
    }
    .swiper-slide > div .main-banner > div {
        margin-top:40px;
    }
    .container {
        width: 1200px;
    }
    .container-small {
        width:970px;
    }
    h1, h2, h1.title-left, h2.title-left, h2.title-center, h2.title-right {
        font-size:62px;
    }
    h1.product-title {
        font-size:36px;
        margin:30px 0;
    }
    section p.strong {
        font-size:32px;
        margin:80px 0 50px;
    }
    .home-top-section > div:first-child {
        max-width:820px;
    }
    .home-top-section > div:nth-child(2) {
        position:absolute;
        z-index:-1;
        top:-50px;
        right:0;
    }
    .home-top-section.information > div:nth-child(2) img {
        width: 420px;
    }
    .home-top-section.information > div:nth-child(2) {
        top:0;
    }
    .home-top-section.products > div:nth-child(2) {
        top:30px;
    }
    .home-top-section.information p.strong {
        margin-top:80px;
    }
    .home-second-section {
        padding:25px 190px;
    }
    .home-second-section.information {
        padding:0 120px 70px 160px;
    }
    .home-second-section.information > div:nth-child(2) ul {
        padding-left:40px;
    }
    .home-wokrs-with {
        margin-bottom:0;
    }
    .white-grad {
        margin-bottom:80px;
    }
    .home-cols {
        margin-bottom:55px;
    }
    .home-cols > div {
        width:25%;
    }
    #footer .footer {
        padding:0 50px 0 150px;
    }
    #footer::after {
        left:calc(50vw - 750px);
    }
    #top .menu > ul > li > a {
        font-size:21px;
        color:#1a4965;
        margin-left:15px;
        margin-right:15px;
        position:relative;
        padding-bottom:15px;
        display: inline-block;
    }
    #top .menu {
        margin-right:55px;
    }
    #top .header-search input {
        width:235px;
    }
    #top {
        padding:0 90px;
    }
    .subcategories > div > a > span span {
        font-size: 32px;
        padding-top:80px;
        padding-left:40px;
    }
    .subcategories > div > a > span em {
        left:40px;
    }
    .banner-text h1, .banner-text h2 {
        padding-bottom:35px;
        margin-bottom:60px;
    }
    h3 {
        font-size:48px;
        margin:40px 0 50px;
    }
    .timeline-block {
        margin-top:50px;
    }
    .timeline > div {
        height:170px;
    }
    .timeline {
        font-size:21px;
        margin:100px 0 300px 20px;
    }
    .timeline > div:nth-child(2n) {
        padding-top:80px;
        top:170px;
    }
    .t-1995 {
        width:250px;
    }
    .t-1996 {
        left:85px;
    }
    .t-2001 {
        width:305px;
    }
    .t-2011 {
        left:400px;
    }
    .t-2012 {
        width:290px;
    }
    .t-2014 {
        left:705px;
    }
    .t-2014 > div {
        width:210px;
    }
    .t-2015 {
        width:210px;
    }
    .t-2018 {
        left:955px;
    }
    .map {
        font-size:24px;
        padding:70px 0 50px;
        margin-top:100px;
    }
    h1.product-title span::after {
        bottom: 10px;
    }
    .product-right {
        padding:0 60px;
    }
    .img-cols.capability > div > a > span span {
        padding:50px 55px 0;
        font-size:32px;
    }
    .contact-btn {
        margin-top:85px;
    }
    #top .menu > ul > li {
        padding-top:48px;
    }
    .products-catalog > div {
        width: calc(20% - 30px);
    }
    .products-catalog > div p {
        font-size: 16px;
        line-height: 24px;
    }
    #top .menu > ul > li > a {
        font-size: 16px;
        color: #1a4965;
        position: relative;
        padding-bottom: 15px;
        display: inline-block;
    }
}
@media (min-width: 1450px) {
    .product-product .container, .product-catalog .container {
        width:1200px;
    }
}
@media (min-width: 1540px) {
    .t-1995 {
        width:285px;
    }
    .t-1995 > div {
        width:200px
    }
    .t-1996 {
        left:105px;
    }
    .t-1996 > div {
        width:235px
    }
    .t-2001 {
        width:365px;
    }
    .t-2001 > div {
        width:260px
    }
    .t-2011 {
        left:465px;
    }
    .t-2011 > div {
        width:210px;
    }
    .t-2012 {
        width:375px;
    }
    .t-2012 > div {
        width:275px
    }
    .t-2014 {
        left:855px;
    }
    .t-2014 > div {
        width:250px;
    }
    .t-2015 {
        width:270px;
    }
    .t-2015 > div {
        width:200px;
    }
    .t-2018 {
        left:1165px;
    }
    .t-2018 > div {
        width:230px;
    }
    .t-2019 {
        width:200px;
    }
    .product-product .container, .product-catalog .container {
        width:1400px;
    }
}

@media (min-width:1900px) {
    #top .menu > ul > li > a {
        font-size: 19px;
    }
}

@media (max-width:1500px) {
    #top .menu ul > li > div > ul {
        width:100%;
        font-size:10px;
        margin:0 auto!important;
    }
    #top .menu ul > li > div > ul > li {
        width:150px;
    }
    #top .menu ul > li > div > ul > li li a {
        line-height:15px;
    }
}

@media (max-width:1440px) {
    #top .menu > ul > li > a {
        font-size: 13px;
    }
}

@media (max-width:1250px) {
    #top .menu ul > li > div > ul > li {
        width:130px;
    }
    #top .menu ul > li > div > ul ul {
        padding-left:7px;
    }
}

@media (max-width: 1050px) {
    #top .menu > ul > li > a {
        font-size:13px;
    }
}

@media (max-width:991px) {
    .hidden-sm {
        display:none!important;
    }
}
@media (max-width:767px) {
    .hidden-xs {
        display:none!important;
    }
    .product-product table td, .product-product table th {
        font-size:14px;
        padding:7px 20px;
    }
}
@media(max-width:479px) {
    .download-wrap > div {
        padding:10px 0 0 0;
        text-align:center;
        width:100%;
    }
}