@charset "utf-8";
/* CSS Document */

/*
Theme Name: SNOCOM theme
Author: VanderVeer Creative Agency
Description: Custom WP Theme
Version: 1.1
Text Domain: theme
Tags:
*/

body, html {
	padding:0;
	margin:0;
    font-family: 'Work Sans', sans-serif;
    font-size:17px;
    line-height: 30px;
    font-weight: 300;
    color:#404040;    
}


* {
	box-sizing: border-box;
}

p {
    font-size:17px;
    line-height: 30px;
    font-weight: 300;
    color:#404040;
}

img.alignnone {
    width:100%;
    height:auto;
}

a {
    color:#F1972C;
}

a.button {
    position: relative;
    display: inline-block;
    padding:8px 26px;
    padding-left:48px;
    border-radius: 100px;
    background-color:#F1972C;
    color:white;
    font-weight: 600;
    font-size:17px;
    line-height: 17px;
    text-decoration: none;
    transition: 0.3s ease;
    margin-right:8px;
    margin-bottom:8px;
}
a.button::before {
    position: absolute;
    left:20px;
    top:49%;
    transform:translateY(-50%);
    content:'';
    display: inline-block;
    height:22px;
    width:20px;

    background-image:url('img/beeldmerk.svg');
    background-size: contain;
    background-position:left center;
    background-repeat: no-repeat;
    transition: 0.3s ease;

}
a.button:hover {
    color:#12519E;
}
a.button:hover::before {
    transform:translateY(-50%) rotate(45deg);
    filter: brightness(0) invert(1);
}

a.altbutton, .altbutton {
    position: relative;
    display: inline-block;
    padding:8px 26px;
    padding-left:48px;
    border-radius: 100px;
    background-color:white;
    color:#F1972C;
    font-weight: 600;
    font-size:17px;
    line-height: 17px;
    text-decoration: none;
    transition: 0.3s ease;
    margin-right:8px;
    margin-bottom:8px;
    cursor: pointer;
}
a.altbutton::before, .altbutton::before {
    position: absolute;
    left:20px;
    top:49%;
    transform:translateY(-50%);
    content:'';
    display: inline-block;
    height:22px;
    width:20px;

    background-image:url('img/beeldmerk.svg');
    background-size: contain;
    background-position:left center;
    background-repeat: no-repeat;
    transition:transform 0.3s ease;
}
a.altbutton:hover, .altbutton:hover {
    color:#12519E;
}
a.altbutton:hover::before, .altbutton:hover::before {
    transform:translateY(-50%) rotate(45deg);
    filter: invert(68%) sepia(89%) saturate(1543%) hue-rotate(340deg) brightness(99%) contrast(81%);
}

.content ul {
    list-style:none;
    margin:15px 0;
    padding:0;
}
.content li {
    position: relative;
    margin:15px 0;
    padding:0 0 0 30px;
}
.content li::before {
    content:'+';
    color:#F1972C;
    font-size:24px;
    line-height: 28px;
    position: absolute;
    left:0;
}

.center {
	text-align: center;
}

.left {
	float:left!important;
}
.right {
	float:right!important;
}
.space-bottom {
	margin-bottom:120px;
}
.space-top {
	margin-top:120px;
}
.space {
	margin-top:120px;
	margin-bottom:120px;
}
.smallspace {
	margin-top:60px;
	margin-bottom:60px;
}

h1 {
    font-size:63px;
    line-height: 66px;
    font-size: clamp(32px, 5vw, 63px);
    line-height: clamp(34px, 5vw, 66px);
    font-weight:600;
    margin:0 0 15px 0;
    color:#F1972C;
}
h2 {
    font-size:48px;
    line-height: 48px;
    font-size: clamp(26px, 4vw, 48px);
    line-height: clamp(26px, 4vw, 48px);
    font-weight:600;
    margin:0 0 35px 0;
    color:#F1972C;
}
h2.big {
    font-size:63px;
    line-height: 66px;
    font-size: clamp(32px, 5vw, 63px);
    line-height: clamp(34px, 5vw, 66px);
}
h3 {
    font-size:24px;
    line-height: 24px;
    font-size: clamp(18px, 2vw, 24px);
    line-height: clamp(18px, 2vw, 24px);
    font-weight:400;
    color:#12519E;
    margin:8px 0;
}

.headercontainer, .container, .midcontainer, .smallcontainer, .minicontainer, .flexrow, .onlyleftcontainer, footer {
    display: flex;
    flex-wrap: wrap;
	position: relative;
	max-width:100%;
	padding-left:15px;
	padding-right:15px;
	margin-left:auto;
	margin-right:auto;
	overflow:hidden;
}
.row, .flexrow {
	width:100%;
	overflow:hidden;
    padding-left:0;
    padding-right:0;
}
.reverse {
    flex-direction: row-reverse;
}
.headercontainer, .container, footer {
	width:1600px;
}
.midcontainer {
	width:1200px;
}
.smallcontainer {
	width:800px;
}
.minicontainer {
	width:450px;
}

.onlyleftcontainer {
    width:calc(50% + 800px);
    max-width: 100%;
    margin-left:auto;
    margin-right:0;
    padding-right:0;
}

.grayback {
    position: relative;
    overflow: visible;
    background-color:#EFEFEF;
}
.graybackshape {
    position: relative;
    overflow: visible;
}
.graybackshape::before {
    content:'';
    position: absolute;
    z-index: -1;
    left:0;
    top:80px;
    width:100%;
    bottom:0;
    background-color:#EFEFEF;
    pointer-events:none;
}
.graybackshape::after {
    content:'';
    position: absolute;
    z-index: -1;
    left:0;
    top:calc(100% - 2px);
    width:100%;
    height:140px;
    background-color:#EFEFEF;
    pointer-events:none;
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 58% 100%, 55% 50%, 0 20%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 58% 100%, 55% 50%, 0 20%);
}
.blueback {
    background-color:#12519E;
    color:white;
}
.bluebackshape {
    position: relative;
    overflow: visible;
    color:white;
}

.blueback p, .bluebackshape p, .blueback h3, .bluebackshape h3 {
    color:white;
}

.bluebackbefore, .bluebackafter {
    position: relative;
    overflow: visible;
}
.bluebackbefore::before {
    content:'';
    position: absolute;
    z-index: -1;
    pointer-events: none;
    top:-180px;
    left:0;
    height:181px;
    width:100%;
    background-color:#12519E;
    -webkit-clip-path: polygon(0 90%, 100% 0, 100% 100%, 0% 100%);
    clip-path: polygon(0 90%, 100% 0, 100% 100%, 0% 100%);
}
.bluebackafter::after {
    content:'';
    position: absolute;
    z-index: -1;
    pointer-events: none;
    bottom:-180px;
    left:0;
    height:181px;
    width:100%;
    background-color:#12519E;
}

.bluebackshape::before {
    content:'';
    position: absolute;
    z-index: -1;
    left:0;
    top:0;
    width:100%;
    bottom:0;
    background-color:#12519E;
    pointer-events:none;
}
.bluebackshape::after {
    content:'';
    position: absolute;
    z-index: -1;
    left:0;
    top:calc(100% - 2px);
    width:100%;
    height:140px;
    background-color:#12519E;
    pointer-events:none;
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 58% 100%, 55% 50%, 0 20%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 58% 100%, 55% 50%, 0 20%);
}

hr {
    border:none;
    width:100%;
    height:1px;
    background-color:#5389CB;
    margin:15px 0;
}
.blueback hr {
    background-color:#F1972C;
}

.div5 {
    width:calc(5% - 12px);
}
.div10 {
    width:calc(10% - 12px);
}
.div15 {
    width:calc(15% - 12px);
}
.div20 {
    width:calc(20% - 12px);
}
.div25, .div25-2 {
    width:calc(25% - 12px);
}
.div30 {
    width:calc(30% - 12px);
}
.div33 {
    width:calc(33% - 12px);
}
.div40 {
    width:calc(40% - 12px);
}
.div45 {
    width:calc(45% - 12px);
}
.div50 {
    width:calc(50% - 12px);
}
.div55 {
    width:calc(55% - 12px);
}
.div60 {
    width:calc(60% - 12px);
}
.div70 {
    width:calc(70% - 12px);
}
.div80 {
    width:calc(80% - 12px);
}

@media screen and (max-width:930px) {
    .space-top {
        margin-top:80px;
    }
    .space-bottom {
        margin-bottom:80px;
    }
    .space {
        margin-top:80px;
        margin-bottom:80px;
    }
    .smallspace {
        margin-top:40px;
        margin-bottom:40px;
    }
    .div10, .div15, .div20, .div25 {
        width:calc(50% - 8px);
    }
    .div25-2, .div30, .div33, .div40, .div45, .div50, .div55, .div60, .div70, .div80 {
        width:100%;
    }
    .bluebackafter::after {
        bottom:-120px;
        height:121px;
    }
}
@media screen and (max-width:580px) {
    .space-top {
        margin-top:60px;
    }
    .space-bottom {
        margin-bottom:60px;
    }
    .space {
        margin-top:60px;
        margin-bottom:60px;
    }
    .smallspace {
        margin-top:30px;
        margin-bottom:30px;
    }
    h2 {
        margin-bottom:15px;
    }

}



header {
    position: fixed;
    z-index: 99;
    background-color:white;
    top:0;
    left:0;
    width:100%;
    height:110px;
    box-shadow: 0 3px 6px 0 rgba(0,0,0,0.16);
}
body {
    padding-top:110px; /* HEIGHT OF HEADER */
}
.headercontainer {
    height:100%;
    align-items: flex-end;
    overflow:  visible;
}
header .logo {
    height:100%;
    width:auto;
    margin-right:15px;
    padding:15px 0;
}
header .logo img {
    height:100%;
    width:auto;
}
header nav {
    margin-left:auto;
    margin-right:0;
}
header nav ul {
    margin:0;
    padding:0;
    list-style: none;
}
header nav li {
    position: relative;
    display: inline-block;
    padding:0;
    margin:0 0 0 25px;
}
header nav a {
    text-transform: uppercase;
    color:#12519E;
    text-decoration: none;
    letter-spacing: 1px;
    padding-bottom:4px;
    transition: 0.3s ease;
}
header nav li.current-menu-item > a, header nav li.current-menu-parent > a {
    font-weight:600;
}
header nav ul:not(.sub-menu) > li:last-child > a {
    display: inline-block;
    padding:4px 60px;
    background-color:#F1972C;
    color:white;
    font-weight:600;
}
header nav ul:not(.sub-menu) > li:last-child > a:hover {
    background-color:#D57A0E;
}

header nav ul.sub-menu li {
    margin:0;
    display: block;
}
header .extranav {
    position: absolute;
    top:12px;
    right:15px;
}
header .extranav ul {
    list-style: none;
    padding:0;
    margin:0;
}
header .extranav li {
    display:inline-block;
    padding:0;
    padding:0 15px 0 15px;
    border-left:1px solid #C6C6C6;
}
header .extranav li:first-child {
    padding-left:0;
    border-left:0;
}
header .extranav li:last-child {
    padding-right:0;
}
header .extranav a {
    text-transform: uppercase;
    color:#12519E;
    text-decoration: none;
    font-size:15px;
    line-height: 18px;
}
.smallscreen-call {
	display:none;
}
.hamburger {
	position: fixed;
    display: none;
	z-index:99;
	top:38px;
	right:15px;
	width:45px;
	height:45px;
	cursor: pointer;
}
.hamburger span {
	display:block;
	position: absolute;
	left:6px;
	height:3px;
	width:33px;
	background:#F1972C;
    border-radius: 100px;
	transition: 0.3s ease;
}
.hamburger span:nth-child(1) {
	top:12px;
}
.hamburger span:nth-child(2) {
	top:21px;
}
.hamburger span:nth-child(3) {
	top:30px;
}

.opennav .hamburger span:nth-child(1) {
	top:21px;
	transform:rotate(45deg);
}
.opennav .hamburger span:nth-child(2) {
	top:21px;
	opacity:0;
}
.opennav .hamburger span:nth-child(3) {
	top:21px;
	transform:rotate(-45deg);
}

@media screen and (min-width:961px) {
    header nav li.menu-item-has-children > a::after {
        display: inline-block;
        margin-left:4px;
        content:' ᐁ';
        color:#12519E;
        font-size:10px;
        transform:TranslateY(-2px);
    }
    header nav li.menu-item-has-children.current-menu-item > a::after, header nav li.menu-item-has-children.current-menu-parent > a::after {
        content:' ▼';
    }
    header nav ul.sub-menu {
        display: none;
        position: absolute;
        z-index: 99;
        top:calc(100% + 10px);
        left:-10px;
        padding:0 10px;
        background:white;
        box-shadow: 0 3px 8px 0 rgba(0,0,0,0.16);
        min-width:160px;
        width:auto;
        white-space: nowrap;
    }
    header nav ul.sub-menu::before {
        content:'';
        position: absolute;
        pointer-events: none;
        width:12px;
        height:12px;
        background:white;
        bottom:calc(100% + 3px);
        left:10px;
        transform:rotate(45deg);
    }
    header nav ul.sub-menu::after {
        content:'';
        position: absolute;
        left:0;
        width:100%;
        bottom:100%;
        height:15px;
        background:transparent;
    }
    header nav li.menu-item-has-children:hover > ul.sub-menu {
        display: block;
    }
    header nav ul.sub-menu > li {
        margin:.5em 0;
    }
}

@media screen and (max-width:1330px) {
    header nav a {
        font-size:16px;
        line-height: 28px;
        letter-spacing: 0;
    }
    header nav li {
        margin:0 0 0 15px;
    }
    header nav ul:not(.sub-menu) > li:last-child > a {
        padding:4px 35px;
    }
}
@media screen and (max-width:1230px) {
    header nav a {
        font-size:16px;
        line-height: 28px;
        letter-spacing: 0;
    }
    header nav li {
        margin:0 0 0 12px;
    }
    header nav ul:not(.sub-menu) > li:last-child > a {
        padding:4px 15px;
    }
}
@media screen and (max-width:960px) {
    header {
        height:90px;
    }
    body {
        padding-top:90px;
    }
    header .logo {
        padding:10px 0;
    }
    header nav {
        display: none;
        position: fixed;
        z-index: -1;
        top:90px;
        left:0;
        right:0;
        height:calc(100vh - 90px);
        background:#12519E;
        overflow:hidden auto;
    }
    header.opennav nav {
        display: block;
    }
    header nav > * {
        height:100%;
    }
    header nav ul {
        position: relative;
        z-index: 5;
        display: flex;
        flex-wrap: wrap;
        padding:35px;
        text-align: center;
        min-height:100%;
        align-content:center;
    }
    header nav li {
        display: block;
        width:100%;
        margin:0 0 20px 0;
    }
    header nav a {
        display: inline-block;
        padding-left:4px;
        font-size: 18px;
        line-height: 22px;
        color:white;
    }
    header nav ul:not(.sub-menu) > li:last-child > a {        
        padding:8px 24px;
        font-size: 18px;
        line-height: 18px;
    }
    header nav li.menu-item-has-children {
        margin-bottom:0;
    }
    header nav ul.sub-menu {
        margin:15px 0;
        padding:0;
        min-height:0;
        height:auto;
    }
    header nav ul.sub-menu a {
        font-size:15px;
        line-height: 18px;
    }
    header nav ul.sub-menu a::before {
        content:'- ';
        font-weight:600;
        color:#F1972C;
    }
    header nav ul.sub-menu a::after {
        content:' -';
        font-weight:600;
        color:#F1972C;

    }
    .hamburger {
        display: block;
        right:8px;
    }
}
@media screen and (max-width:630px) {
    header {
        height:70px;
        padding-bottom:0;
    }
    body {
        padding-top:70px;
    }
    header .logo {
        padding:8px 0;
    }
    .hamburger {
        top:13px;
    }
    header nav {
        top:70px;
        padding-top:70px;
        height:calc(100vh - 70px);
    }
    header nav li {
        margin:0 0 12px 0;
    }
    header .extranav {
        display: none;
        position: fixed;
        z-index: 999;
        top:70px;
        right:0;
        width:100%;
        padding:8px 15px;
        background:white;
        min-height:65px;
    }
    header.opennav .extranav {
        display: block;
    }
    header .extranav li {
        display: block;
        width:100%;
        margin:8px 0;
        padding:0;
        border:none;
    }
    .smallscreen-call {
        display: block;
        position:fixed;
        top:24px;
		right:80px
    }
    .smallscreen-call img {
        height:23px;
        width:auto;
    }
}

.imgwrap-1 {
    position: relative;
    width:100%;
    height:0;
    padding-top:40%;
}
.imgwrap-2 {
    position: relative;
    width:100%;
    height:0;
    padding-top:36%;
}
.imgwrap-3 {
    position: relative;
    width:100%;
    height:0;
    padding-top:55%;
}
.squareimg, .squareimg-blue {
    position: relative;
    z-index: 1;
    width:100%;
    height:0;
    padding-top:75%;
}
.imgwrap-1 img, .imgwrap-2 img, .imgwrap-3 img, .squareimg img, .squareimg-blue img {
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    object-fit: cover;
    object-position: center;
}
.squareimg-blue::after {
    content:'';
    position: absolute;
    z-index: -1;
    left:-15px;
    top:30%;
    bottom:-45px;
    right:-300px;
    background:#12519E;
}
.reverse .squareimg-blue::after {
    content:'';
    position: absolute;
    z-index: -1;
    left:-300px;
    top:30%;
    bottom:-45px;
    right:-15px;
    background:#12519E;
}

.hero {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    /*padding-top:clamp(530px, 100vh, 930px);*/
    min-height:530px;
    height:calc(100vh - 230px);
    max-height:860px;
    padding-top:280px;
    width:100%;
    background-color:#12519E;
    background-size:cover;
    background-position: center;
    margin-bottom:230px;
}
.contact-hero {
    background-color:#EFEFEF; 
    padding-top:0px;
    margin-bottom:120px;
    align-content: flex-end;
    min-height: 0;
    height:auto;
    max-height:none;
}

.applications-hero {
    min-height:460px;
    height:calc(100vh - 360px);
    padding-top:80px;
    margin-bottom:60px;
}
.hero-img {
    position: absolute;
    z-index: 0;
    top:0;
    left:0;
    width:100%;
    height:100%;
}
.hero-img img {
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    object-fit: cover;
    object-position: center;
}

.video-wrap {
    position: absolute;
    z-index: 0;
    top:0;
    left:0;
    width:100%;
    height:100%;
    overflow: hidden;
}
.video-wrap video {
    position: absolute;
    pointer-events: none;
    top:50%;
    left:50%;
    transform:translateX(-50%) translateY(-50%);
    height: 100%;
    width: 177.77777778vh; /* 100 * 16 / 9 */
    min-width: 100%;
    min-height: 56.25vw; /* 100 * 9 / 16 */
}

.hero-content {
    position: relative;
    z-index: 1;
    background:white;
    padding:35px 60px;
    margin-bottom:-120px;
    overflow: visible;
}

.hero-float-content {
    align-self:flex-start;
}
@media screen and (min-width:931px) {
    .hero-content{
        padding-left:min(80px, 5%)!important;
    }
    .deskspace {
        margin-top:160px;
    }
}
.hero .playvid, .hero-icon {
    position: absolute;
    z-index: 105;
    bottom:100%;
    display: block;
    background:#12519E;
    padding:10px 15px;
    color:white;
    text-align: center;
    text-decoration: none;
    transition: 0.3s ease;
}
.hero-icon {
    background:white;
    padding:10px 25px;
}
.hero-icon img {
    display: block;
    width:40px;
    height:35px;
    object-fit: contain;
    object-position: center;
}
.hero .playvid:hover {
    background:#F1972C;
}
.hero .playvid svg {
    display: block;
    width:100%;
    height:26px;
    margin-bottom:10px;
}
.hero .playvid span {
    display: block;
    width:100%;
    font-weight:400;
    text-transform: uppercase;
    font-size:15px;
    line-height: 18px;
}
.hero-content h1 {
    position: relative;
    margin-bottom:50px;
}
.hero-content h1::after {
    content:'';
    position: absolute;
    bottom:-25px;
    left:0;
    height:3px;
    background-color:#F1972C;
    width:148px;
    max-width: 60%;
}
.hero-cta {
    position: absolute;
    z-index: 2;
    bottom:-120px;
    right:0;
    width:calc(50% - 160px);
    -webkit-clip-path: polygon(80px 80px, 100% 0, 100% 100%, 0% 100%);
    clip-path: polygon(80px 80px, 100% 0, 100% 100%, 0% 100%);
}
.hero-cta-content {
    width:640px;
    max-width: 100%;
    padding:140px 15px 80px 140px;
}
.hero-cta .button {
    margin-top:35px;
}

@media screen and (max-width:1600px) {
    .hero-cta {
        width:40%;
    }
}
@media screen and (max-width:1130px) {
    .hero-content {
        padding:25px 35px;
    }
    .hero-cta {
        -webkit-clip-path: polygon(50px 50px, 100% 0, 100% 100%, 0% 100%);
        clip-path: polygon(50px 50px, 100% 0, 100% 100%, 0% 100%);
    }
    .hero-cta-content {
        width:640px;
        max-width: 100%;
        padding:90px 15px 40px 90px;
    }
}
@media screen and (max-width:930px) {
    .hero {
        padding-top:0;
        height:auto;
        max-height:none;
        min-height:0;
        align-items:flex-start;
        margin-bottom:60px;
    }
    .hero-img {
        position: relative;
        width:100%;
        padding-top:56.25%;
        height:0;
        margin-bottom:-15px;
    }
    .applications-hero {
        margin-bottom:35px;
    }
    .applications-hero .hero-img {
        margin-bottom:15px;
    }
    .applications-hero h3 {
        color:white;
    }
    .hero-content {
        margin-bottom:0;
        -webkit-clip-path: polygon(0 15px, 100% 0, 100% 100%, 0% 100%);
        clip-path: polygon(0 15px, 100% 0, 100% 100%, 0% 100%);
        padding-top:40px;
    }
    .hero-cta {
        width:100%;
        position: relative;
        bottom:auto;
        right:auto;
        -webkit-clip-path: none;
        clip-path: none;
    }
    .hero-cta-content {
        padding:35px 35px;
    }
    .hero .playvid {
        position: relative;
        display: inline-block;
        bottom:auto;
        right:auto;
        padding:2px 20px;
        border-radius: 100px;
        margin-top:15px;
    }
    .hero-icon {
        position: relative;
        bottom:auto;
        right:auto;
        padding:0;
        margin-top:15px;
    }
    .hero-icon img {
        object-fit: center left;
    }
    .hero .playvid svg {
        display:inline-block;
        height:14px;
        transform:TranslateY(2px);
        margin-bottom:0;
        margin-right:8px;
        width:auto;
    }
    .hero .playvid span {
        display:inline-block;
        font-size:14px;
        line-height: 14px;
        width:auto;
    }
}
@media screen and (max-width:530px) {
    .hero-content {
        padding:25px 15px;
        padding-top:40px;
    }
    .hero-cta-content {
        padding:35px 15px;
    }
    .hero-cta .button {
        margin-top:15px;
    }
}

.usps {
    column-gap: 15px;
    padding-top:5px;
    padding-bottom:15px;
}
.usp {
    position: relative;
    z-index: 5;
    background-color:white;
    overflow: hidden;
    flex: 1 1 calc(33% - 15px);
    max-width: 50%;
    box-shadow: 0 5px 10px 0 rgba(0,0,0,0.16);
    padding:35px;
    margin-bottom:15px;
}
.blueback .usp {
    background-color:transparent;
}

.usp .icon {
    position: relative;
    height:85px;
    width:auto;
    margin-bottom:35px;
    filter: invert(24%) sepia(42%) saturate(3304%) hue-rotate(199deg) brightness(87%) contrast(91%);
}
.usp .icon img {
    height:100%;
    width:auto;
    filter: brightness(0) saturate(100%);
}
.usp .number {
    font-weight:600;
    font-size:22px;
    line-height: 22px;
    opacity:0.4;
    margin:0 0 25px 2px;
}
.usp h3 {
    position: relative;
    color:#404040;
    font-weight:600;
    padding:5px 0;
}
.usp h3::before {
    content:'';
    position: absolute;
    z-index: 1;
    top:0;
    left:-35px;
    width:5px;
    height:100%;
    background-color:#F1972C;
}

.usp p {
    color:#9B9B9B;
}

.blueback .usp h3, .blueback .usp p {
    color:white;
}

@media screen and (min-width:1081px) {
    .usps-3 .usp {
        flex: 1 1 calc(33% - 15px);
        max-width: 50%;
        padding:35px;
    }
    .usps-4 .usp {
        flex: 1 1 calc(25% - 15px);
        max-width: 50%;
        padding:25px;
    }
    .usps-4 .usp h3::before {
        left:-25px;
    }
}   
@media screen and (max-width:1080px) {
    .usp {
        flex: 1 1 calc(50% - 15px);
    }
}
@media screen and (max-width:730px) {
    .usp {
        flex: 1 1 100%;
        max-width: 100%;
    }
}

.application-slider .slide {
    position: relative;
    margin-right:35px;
    width:480px;
    max-width:70vw;
}
.testimonial-slider .slick-track {
    display: flex;
    flex-wrap:wrap;
    align-items:stretch;
}
.testimonial-slider .slide {
    position: relative;
    margin-right:35px;
    width:770px;
    max-width: calc(50vw - 33px);
    background-color:white;
    padding:60px;
    box-shadow: 0 0 6px 0 rgba(0,0,0,0.16);
    height:auto;
    margin-top:6px;
    margin-bottom:6px;
}
.testimonial-slider .slide::before {
    position: absolute;
    content:'“';
    font-size:200px;
    line-height: 150px;
    color:#12519E;
    left:50px;
    top:15px;
}
.testimonial-slider .slide-content {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    height:100%;
    position: relative;
    color:#12519E;
}
.testimonial-slider .slide-content .flexrow {
    margin-top:auto;
    border-top:1px solid #F1972C;
    padding-top:25px;
    align-items: center;
}
.testimonial-slider hr {
    background-color:#F1972C;
}
.testimonial-slider p {
    color:#12519E;
}
.slide-img {
    position: relative;
    width:100%;
    height:0;
    padding-top:100%;
}
.slide-img img {
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position: center;
}
.application-slider .slide-content {
    position: absolute;
    z-index: 2;
    top:35px;
    left:35px;
    color:white;
    font-weight:600;
}
.application-slider .slide-content .icon {
    display: inline-block;
    margin-right:15px;
    float:left;
}
.application-slider .slide-content .icon img {
    height:30px;
    width:Auto;
    filter:  brightness(0) invert(1);
    -webkit-filter:  brightness(0) invert(1);
}
.slide-logo {
    width:90%;
    height:70px;
    position: relative;
}
.slide-logo img {
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    object-fit: contain;
    object-position: center left;
}
.application-slider .slide-content span {
    display: inline-block;
    float:left;
    font-size:20px;
    line-height: 35px;
}
.slide-overlay {
    background-color:rgba(18,81,158,0.8);
    position: absolute;
    z-index: 1;
    top:0;
    left:0;
    width:100%;
    height:100%;
    display: flex;
    flex-wrap:wrap;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding:35px;
    color:white;
    opacity:0;
    transition: 0.3s ease;
}
.slide-overlay p {
    color:white;
    display: -webkit-box;
    -webkit-line-clamp: 8;
    -webkit-box-orient: vertical;  
    overflow: hidden;
}
.slide:hover .slide-overlay {
    opacity:1;
}
@media screen and (max-width:930px) {
    .application-slider .slide-content {
        left:15px;
        top:15px;
    }
    .slide-overlay {
        padding:15px;
    }
    .slide-overlay, .slide-overlay p {
        font-size:16px;
        line-height: 24px;
    }
    .slide-overlay p {
        display: -webkit-box;
        -webkit-line-clamp: 5;
        -webkit-box-orient: vertical;  
    }
    .testimonial-slider .slide {
        padding:35px;
    }
    .testimonial-slider .slide::before {
        left:25px;
        top:0;
    }
}
@media screen and (max-width:580px) {
    .slide-overlay, .slide-overlay p {
        font-size:15px;
        line-height: 20px;
    }
    .application-slider .slide-content .icon img {
        height:25px;
    }
    .application-slider .slide-content span {
        font-size:18px;
        line-height: 25px;
    }
    .testimonial-slider .slide {
        width:calc(100vw - 30px);
        max-width: none;
    }
    .slide-overlay p {
        display: -webkit-box;
        -webkit-line-clamp: 4;
        -webkit-box-orient: vertical;  
    }
}
@media screen and (max-width:430px) {
    .slide-overlay p {
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;  
    }
    .application-slider .slide-content .icon img {
        height:20px;
    }
    .application-slider .slide-content span {
        font-size:15px;
        line-height: 22px;
    }
}

.dots {
    display:inline-block;
    float:left;
    width:calc(100% - 130px);
    margin-right:30px;
}

.slick-dots {
    display: flex;
    margin:0;
    padding:0;
    list-style:none;
}
.slick-dots li {
    position: relative;
    margin:0;
    padding:0;
    flex: 1 1 0px;
    height:35px;
    cursor: pointer;
}
.slick-dots li::before {
    content:'';
    position: absolute;
    top:calc(50% - 3px);
    width:100%;
    height:6px;
    background:white;
    transition: 0.3s ease;
}
.slick-dots li:hover::before {
    background:#E8E8E8;
}
.slick-dots li.slick-active::before {
    background:#D5D5D5;
}
.slick-dots li button {
    display: none;
}

.arrows {
    display:inline-block;
    float:left;
    width:100px;
}
.prev-arrow, .next-arrow {
    position: relative;
    display: inline-block;
    width:36px;
    height:36px;
    border-radius: 100px;
    border:2px solid #F1972C;
    text-align: center;
    cursor: pointer;
    transition: 0.3s ease;
}
.prev-arrow:hover, .next-arrow:hover {
    background-color:white;
}
.prev-arrow img, .next-arrow img {
    position: absolute;
    top:50%;
    left:50%;
    transform:translateX(-50%) translateY(-50%);
    width:14px;
    height:14px;
    object-fit: contain;
    object-position: center;
}
.next-arrow img {
    transform:translateX(-50%) translateY(-50%) rotate(180deg);
}

.floatspecs {
    position: absolute;
    z-index: 2;
    top:0;
    left:15px;
    height:auto;
    width:calc(100% - 30px);
    background:white;
    transform:TranslateY(-50%);
    border-radius: 8px;
    box-shadow: 0 3px 8px 0 rgba(0,0,0,0.16);
}
.hero-floatspecs {
    position: relative;
    z-index: 2;
    height:auto;
    width:100%;
    background:white;
    border-radius: 8px;
    box-shadow: 0 3px 8px 0 rgba(0,0,0,0.16);
}
.spec {
    flex:1 1 calc(100% / 7);
    text-align: center;
    border-right: 1px solid #C6C6C6;
    padding:25px 15px;
    text-decoration: none;
    color:#404040;
    transition: 0.3s ease;
}
a.spec:hover {
    background-color:#F0F0F0;
}
.spec:last-child{
    border-right: none;
}
.spec .icon {
    position: relative;
    width:50px;
    height:45px;
    margin:0 auto 5px auto;
    text-align: center;
}
.spec .icon img {
    position: absolute;
    top:0;
    left:0;
    height:100%;
    width:100%;
    object-fit: contain;
    object-position: center;
}
.spec-title {
    font-weight:600;
}
.spec p {
    margin:0;
}

@media screen and (max-width:1600px) {
    .floatspecs {
        position: relative;
        top:auto;
        left:auto;
        width:100%;
        transform:none;
        border-radius:0;
    }
}
@media screen and (max-width:1100px) {
    .spec {
        flex:1 1 300px;
        border-bottom: 1px solid #C6C6C6;
    }
}
@media screen and (max-width:600px) {
    .floatspecs .icon, .hero-floatspecs .icon {
        height:35px;
    }
}


.product-div-hero {
    overflow:visible;
}
.product-content-hero, .product-img-hero {
    width:100%;
}
@media screen and (min-width:931px) {
    .product-content-hero {
        flex:1 1 0px;
    }
    .product-img-hero {
        width:694px;
        max-width: 60%;
        align-self: flex-end;
        transform:translateY(40px);
        margin-top:-40px;
    }
    .product-content-hero p {
        width:100%;
    }
}
@media screen and (min-width:1131px) {
    .product-content-hero p {
        width:75%;
    }
    .product-img-hero {
        max-width: 50%;
    }
}
@media screen and (min-width:1601px) {
    .product-img-hero {
        margin-bottom:80px;
    }
}
.product-div-1 {
    position: relative;
    z-index: 1;
    margin-bottom:0;
    padding-top:60px;
}
.product-content-1, .product-img-1 {
    width:100%;
}
.product-img-1 img {
    display: block;
    width:100%;
    margin-bottom:-138px;
}

@media screen and (min-width:931px) {
    .product-content-1 {
        width:630px;
        max-width: 50%;
    }
    .product-img-1 {
        flex:1 1 0px;
        align-self:flex-end;
    }
    .product-img-1 img {
        transform:translateY(138px);
        margin-bottom:0;
    }
}
@media screen and (min-width:1131px) {
    .product-content-1 {
        width:630px;
        max-width: 60%;
    }
    .product-img-1 {
        
    }
}
@media screen and (min-width:1601px) {
    .product-div-1 {
        padding-top:160px;
    }
}

.product-div-2 {
}
.product-div-2 > * {
    align-items:center;
}
.product-content-2 {
    margin-top:140px;
}
.product-content-2 p {
    width:530px;
    max-width: 100%;
}
.product-img-2 img {
    display: block;
    width:100%;
}

@media screen and (max-width:1030px) {
    .product-content-2 {
        margin-top:160px;
    }
}
@media screen and (max-width:930px) {
    .product-img-2 {
        position: relative;
    }
    .product-img-2::before {
        content:'';
        width:calc(100% + 30px);
        height:100%;
        position: absolute;
        z-index: -1;
        top:0;
        left:-15px;
        background:#12519E;
    }
    .product-content-2 {
        margin-top:180px;
    }
    .product-img-2 img {
        max-height:380px;
        object-fit: contain;
        object-position: center;
    }
}
.product-content-3, .product-img-3 {
    width:100%;
}
.product-content-3 p {
    width:530px;
    max-width: 100%;
}
.product-img-3 img {
    position: relative;
    z-index: 1;
    display: block;
    width:100%;
}

/*
.product-div-4 {
    padding:60px 0;
}
.product-content-4 {
    margin-bottom:35px;
    text-align: center;
    width:430px;
    max-width: 100%;
    margin-left:auto;
    margin-right:auto;
}
.product-content-4 h2 {
    font-size:63px;
    line-height: 66px;
    font-size: clamp(32px, 5vw, 63px);
    line-height: clamp(34px, 5vw, 66px);
}
.product-content-4 h3 {
    display: block;
    padding:5px 15px;
    background:white;
    text-transform: uppercase;
    color:#12519E;
}
.product-img-4 {
    max-width: 80%;
    margin-left:auto;
    margin-right:auto;
    align-self: flex-end;
}
.product-img-4 img {
    display: block;
    width:100%;
}
*/
@media screen and (max-width:480px) {
    .product-img-4 {
        max-width:100%;
    }
}
@media screen and (min-width:931px) {
    .product-div-3 {
        overflow: visible;
    }
    .product-content-3 {
        width:580px;
        margin-right:5%;
        max-width: 50%;
        margin-bottom:80px;
    }
    .product-img-3 {
        flex:1 1 0px;
        align-self:flex-end;
        margin-bottom:-80px;
        margin-right:5%;
    }
    .product-div-4 {
        margin-top:120px;
    }
/*
    .product-div-4 {
        overflow: visible;
        padding:0;
    }
    .product-content-4 {
        margin-top:240px;
        text-align: center;
        align-self:flex-end;
        margin-bottom:80px;
    }
    .product-content-4 p {
        width:460px;
        margin-left:auto;
        margin-right:auto;
        max-width: 100%;
    }
    .product-img-4 {
        margin-top:-40px;
        margin-bottom:-80px;
        flex:1 1 0px;
    }
*/
}

@media screen and (min-width:1131px) {
    .product-content-3 {
        width:630px;
        max-width: 60%;
    }
    .product-img-3 {
        
    }
/*
    .product-img-4 {
        margin-top:-80px;
        margin-bottom:-80px;
    }
    .product-content-4 {
        width:580px;
        margin-bottom:120px;
    }
*/
}

.news-item {
    margin-bottom:80px;
    position: relative;
    z-index: 1;
}
.news-item > div {
    align-items: center;
}
.news-item .squareimg {
    box-shadow: 0 0 6px 0 rgba(0,0,0,0.16);
    margin-bottom:6px;
}
.news-item:nth-child(even) > div {
    /*flex-direction: row-reverse;*/
}
.news-item:nth-child(3n - 1) {
    z-index: 0;
    background:#EFEFEF;
    padding-top:120px;
    padding-bottom:160px;
    margin-top:-120px;
    margin-bottom:-80px;
}

@media screen and (min-width:530px) and (max-width:930px) {
    .other-news {
        display: flex;
        flex-wrap: wrap;
        column-gap: 2%;
    }
    .other-news a {
        width:49%;
    }
}
.other-news-content {
    position: absolute;
    z-index:2;
    bottom:8px;
    left:8px;
    width:calc(100% - 16px);
}
.other-news a {
    display: block;
    position: relative;
    margin-bottom:35px;
}
.other-news .news-date {
    display: inline-block;
    float:left;
    background:#12519E;
    color:white;
    padding:2px 8px;
    font-size:14px;
    line-height: 14px;
    margin:0;
}
.other-news h3 {
    display: inline-block;
    float:left;
    width:100%;
    background:white;
    padding:2px 8px;
    font-size:16px;
    line-height: 18px;
    margin:0;
    box-shadow:0 0 4px 0 rgba(0,0,0,0.16);
}
.other-news .imgwrap-3::before {
    content:'';
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background-color:#12519E;
    pointer-events: none;
    opacity:0.36;
    z-index: 1;
    transition:0.3s ease;
}
.other-news a:hover .imgwrap-3::before {
    opacity:0;
}


.single-news-content {
    
}
.single-news-content .news-date {
    display: inline-block;
    background:#12519E;
    color:white;
    padding:8px 8px;
    margin:0;
    margin-right:15px;
}
.single-news-content h1 {
    display: block;
    float:left;
    margin:15px 0;
    width:100%;
}

.single-share {
    display: inline-block;
    float:right;
    padding-top:10px;
}
.single-share .addtoany_shortcode {
    display: inline-block;
}
.single-share a {
    display: inline-block;
    position: relative;
    z-index: 1;
    color:white;
    margin-right:12px;
}
.single-share a path {
    fill:white;
}
.single-share a::before {
    display: block;
    position: absolute;
    content:'';
    width:35px;
    height:35px;
    top:calc(50% - 4px);
    left:50%;
    transform:translateY(-50%) translateX(-50%);
    background:#12519E;
    border-radius: 100px;
}

@media screen and (max-width:930px) {
    .news-item {
        margin-bottom:100px;
    }
    .news-item:nth-child(3n - 1) {
        padding-top:60px;
        padding-bottom:160px;
        margin-top:-60px;
        margin-bottom:-80px;
    }
    .single-news-content .news-date {
        padding:8px 8px;
        font-size:14px;
        line-height: 18px;
    }
    
    .single-share {
        padding-top:6px;
    }
    
}
@media screen and (max-width:480px) {
    .single-share {
        display: block;
        float:none;
        margin-top:8px;
    }
}

.news-date {
    color:#12519E;
    font-weight: 400;
    font-size:18px;
    line-height: 24px;
}
.news-item a.altbutton {
    background:transparent;
    padding-left:30px;
}
.news-item a.altbutton::before {
    left:0;
}

.share a span {
    position: relative;
    z-index: 1;
    overflow: visible;
    margin-right:15px;
}
.share a span::before {
    content:'';
    position: absolute;
    z-index: -1;
    pointer-events: none;
    top:50%;
    left:50%;
    width:32px;
    height:32px;
    transform:translateX(-50%) translateY(-50%);
    border-radius: 100px;
    border: 1px solid #404040;
}
@media screen and (min-width:931px) {
    .share {
        align-self: flex-start;
        text-align: center;
    }
    .share a {
        display: block!important;
        margin:15px 0;
    }
    .share a span {
        display: block!important;
        margin:auto;
        position: relative;
        z-index: 1;
        overflow: visible;
    }
}
@media screen and (max-width:930px) {
    .share {
        width:100%;
    }
}


.video_popup {
    position: fixed;
    z-index: 101;
    top:0;
    left:0;
    width:100%;
    height:100%;
    padding:80px;
    display: none;
}
.video_popup_bg {
    position: absolute;
    z-index: 1;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:rgba(18,81,158,0.80);
    cursor: pointer;
}
.video_popup_bg::after {
    content:'×';
    font-weight:600;
    font-size:60px;
    line-height: 60px;
    color:white;
    z-index: 3;
    position: absolute;
    top:15px;
    right:15px;
    width:40px;
    height:40px;
}
.video_wrap {
    z-index: 2;
    position: absolute;
    pointer-events: none;
}
.video_wrap video, .video_wrap iframe {
    position: absolute;
    top:50%;
    left:50%;
    transform:translateX(-50%) translateY(-50%);
    width:90%;
    height:90%;
    pointer-events: all;
}

@media (min-aspect-ratio: 16/9) {
	.video_wrap {
		width: 177.777vh;
		height: 100vh;
		position: absolute;
		top:0;
		left: 50%;
        transform:translateX(-50%);
	}
}

@media (max-aspect-ratio: 16/9) {
	.video_wrap {
		width: 100%;
        height:0;
		padding-top: 56.25%;
		position: absolute;
		top: 50%;
		left: 0;
		transform:translateY(-50%);
	}
}

@media (aspect-ratio: 16/9) {
	.video_wrap {
		width: 100%;
		padding-top: 56.25%;
        height:0;
		position: absolute;
		top: 50%;
		left: 50%;
        transform:translateX(-50%) translateY(-50%);
	}
}


.form {
    color:#12519E;
    font-size:18px;
    line-height: 22px;
    font-weight:400;
}
.floatform {
    background:white;
    padding:35px;
    color:#12519E;
    box-shadow: 0 3px 6px 0 rgba(0,0,0,0.16);
    margin-bottom:-80px;
    font-size:18px;
    line-height: 22px;
    font-weight:400;
}
.form p, .form h3 {
    color:#12519E;
}
.form form {
    width:530px;
    max-width: 100%;
}
.floatform form, .calcform form {
    width:100%;
}
.form form * {
    
}
.form form .flexrow {
    justify-content: space-between;
}
.form form input, .form form textarea {
    width:100%;
    font-size:inherit;
    font-family:inherit;
    line-height:inherit;
    font-weight:300;
    padding:4px 8px;
    border:1px solid #9B9B9B;
    border-radius: 0;
}
.form form textarea {
    max-height:140px;
    resize:none;
}
.form form select {
    width:100%;
    font-size:inherit;
    font-family:inherit;
    line-height:inherit;
    font-weight:300;
    padding:8px 8px;
    border:1px solid #9B9B9B;
    border-radius: 0;
}
.form label {
    font-weight:300;
    margin-bottom:15px;
}
.form input[type="submit"] {
    width:auto;
    -webkit-appearance:none;
    border:none;
    border-radius: 100px;
    background-color:#F1972C;
    color:white;
    font-weight: 600;
    padding:5px 25px;
    display: block;
    cursor: pointer;
    transition: 0.3s ease;
    margin-left:auto;
    margin-right:0;
}
.form input[type="submit"]:hover {
    color:#12519E;
}
.form .answer {
    font-size:28px;
    line-height: 38px;
}

.placeholder {
    font-weight:600;
    font-size:20px;
    line-height: 24px;
    color:#F1972C;
}

@media screen and (max-width:580px) {
    .form {
        padding:15px;
    }
}



.contact-info ul {
    margin:0;
    padding:0 0 0 35px;
    list-style: none;
}
.contact-info li {
    position: relative;
    margin:15px 0;
    padding:0;
}
.contact-info a {
    text-decoration: none;
    color:white;
}
.contact-icon {
    position: absolute;
    width:20px;
    height:20px;
    object-fit: contain;
    object-position: left center;
    left:-35px;
    top:5px;
}

.socials ul {
    margin:0;
    padding:0;
    list-style: none;
}
.socials li {
    display: inline-block;
    margin:0 0 15px 0;
}
.socials a {
    display: inline-block;
    position: relative;
    text-decoration: none;
    color:white;
    width:35px;
    height:35px;
    padding-top:3px;
    border:1px solid white;
    border-radius: 100px;
    text-align: center;
}
.socials img {
    text-align: center;
    width:18px;
    height:18px;
    object-fit: contain;
    object-position: center;
}

@media screen and (max-width:1615px) {
    footer {
        padding:0;
    }
}
.footer-section {
    background-color:#292929;
    color:white;
    padding:60px;
    padding-bottom:8px;
}
.footer-section p {
    color:white;
    margin-bottom:0;
}
.footer-section a {
    color:white;
}
.footer-section ul {
    list-style: none;
    margin:0;
    padding:0;
}
.footer-logo {
    margin-bottom:60px;
}
.footer-links ul.sub-menu {
    display: none;
}
.footer-logo img {
    filter: brightness(0) invert(1);
    width:260px;
    max-width: 80%;
    height:auto;
}
.footer-section a.button {
    margin-top:15px;
}
@media screen and (max-width:580px) {
    .footer-section {
        padding:30px 15px;
    }
    .footer-section .div20 {
        width:100%;
    }
}
