@import url('https://fonts.googleapis.com/css?family=Montserrat:500,800');

body{
    --darkblue: #3161a4;
    --lightblue: #769fcd;
    --accentblue: #d6e6f2;
    --accentwhite: #f7fbfc;
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: 14px;
    color: #222;
}
*{
    box-sizing: border-box
}
*:focus{
    outline: none;
}
body{
    padding:0;
    margin: 0;
}

a{
    text-decoration: none;
}

.container{
    width:1140px;
    margin:0 auto;
}
header{
    background-color: var(--darkblue);
    padding:1.5em 0;
}
header .container{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;    
}
header img{
    width: 140px;
}

.links a{
    padding-left: 20px;
    color:white;
}

footer{
    background-color: var(--lightblue);
    padding:4em 0;
    margin-top: 4em;
}
footer .container{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;    
}
footer .container div{
    width:100%;
    padding: 0 40px 0 0;
    color: var(--accentwhite);
}
form{
    display:flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: stretch;
    justify-content: center;
}
label{
    display:flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    width:33.33%;
    flex-direction: column;
}

label span{
    display: flex;
    flex:1;
    width:100%;
    margin-top: 2px;
}
label input[type=text], label input[type=email], label textarea{
    width:100%;
    background-color: transparent;
    padding:7px 10px;
    border:1px solid var(--accentwhite);
    border-bottom: 1px solid var(--accentwhite);
    box-shadow: inset 0px -5px 0px 0px white;
}

footer input[type=submit]{
    width:25%;
    background-color: var(--accentwhite);
    padding:8px 7px 12px;
    margin-top: 1em;
    border:0px solid var(--accentwhite);
    cursor: pointer;
    color: var(--lightblue);
    text-transform: uppercase;
    border-radius: 4px;
    box-shadow: inset 0px -4px 0px 2px #ddd;
    /* transition: all 0.2s cubic-bezier(0.165, 0.84, 0.44, 1); */
}
footer input[type=submit]:hover, footer input[type=submit]:focus{
    box-shadow: inset 0px 0px 0px 2px #ddd;
    padding:10px 7px 10px;
}

footer div a{
    color: var(--accentwhite);
    display: block;
    padding: 20px;
}

.copyright .container{
    display: block;
    margin: 2em auto 0;
    color: var(--accentwhite);
    font-size:0.75em;
    border-top:1px solid var(--accentblue);
    padding-top: 2em;
}

.hero{
    width: 100%;
    position: relative;
    padding: 8em 0;
    margin-bottom: 4em;
}

.hero img{
    position: absolute;
    top: 0;
    left: 0;
    width:100%;
    height: 100%;
    object-fit: cover;
    z-index: -1;
}

.hero p{
    background-color: var(--lightblue);
    padding:2em;
    color: var(--accentwhite);
    display: inline-block;
    max-width: 360px;
    font-size: 2em;
}

.card{
    display:flex;
    flex-wrap:wrap-reverse;
    align-items: center;
    margin-bottom: 4em;
}

.card div{
    width:50%;
}

.card .textbox{
    background-color: var(--accentwhite);
    padding:40px;
    z-index: 3;
}

.card .image{
    overflow: visible;
}

.image img{
    width:calc(100% + 60px);
    transform: translateX(-60px);
    z-index:-1;
}

.productcat{
    display:flex;
    flex-wrap: wrap;
    background-image: url('images/img-2.jpg');
    background-size: cover;
    padding: 14em 0;
}
.productcat .container{
    display:flex;
    flex-wrap: wrap;
}
.productcat a{
    position:relative;
    width:25%;
    text-align: center;
    color: var(--accentwhite);
}

.productcat h2{
    position: relative;
    z-index: 2;
}

.productcat a:before{
    content:'';
    position: absolute;
    top: 50%;
    left: 50%;
    width:70%;
    height:0;
    border-radius: 50%;
    transform: translate(-50%,-50%);
    z-index: 1;
    padding-top: 70%;
    background-color: var(--darkblue);
}


/* .pro{
    width: 50%;
    background-color: var(--accentwhite);
    overflow: hidden;
    padding-top: 2em;
    color: #222;
}

.pro:hover{
    opacity: 0.65;
}

.pro:last-of-type{
    background-color: var(--accentblue);
}
 */
.pro h2{
    font-weight: 500;
    text-transform: uppercase;
    width:100%;
    text-align:center;
}

/* .pro img{
    width:100%;
    height: 300px;
    object-position: bottom;
    object-fit: contain;
    transform: translateY(4em);
} */

.vision{
    background-color: var(--accentblue);
    padding: 4em 0;
    margin-bottom: 4em;
}

.vision .container{
    display:flex;
    flex-direction: row-reverse;
    align-items: center;
    margin-bottom: 4em;
}

.vision .container div{
    width:50%;
}

.vision .container .textbox{
    background-color: var(--accentwhite);
    padding:40px;
    z-index: 3;
}

.vision .container .image{
    overflow: visible;
}

.vision .container .image img{
    width:calc(100% + 60px);
    transform: translateX(0px);
    z-index:-1;
}


.productlist h2{
    width:100%;
}

.productlist{
    display:flex;
    flex-wrap: wrap;
    align-items: center;
    position: relative;
}

.productlist .loader{
    position: absolute;
}

.productlist .container{
    display:flex;
    flex-wrap: wrap;
    margin:4em auto 0;
}

.productlist .product{
    width:25%;
    padding:1em 4em;
}

.product a{
    color: #222;
    text-align:center;
}

.product img{
    width:100%;
}

.productlist button{
    width:33.33%;
    margin: 0 0 2em;
    padding: 15px 10px;
    border: 0px solid var(--darkblue);
    background-color: var(--accentwhite);
    color: var(--darkblue);
    cursor: pointer;
    font-size: 1.25em;
    text-transform: uppercase;
}
.productlist button.active{
    background-color: var(--darkblue);
    color: var(--accentwhite);
}