@charset "utf-8";
/* CSS Document */

/* ============ FONT-ICONS ============ */

@font-face {
  font-family:"SSGizmo";
	src: url('webfonts/ss-gizmo.css');
  	src: url('webfonts/ss-gizmo.eot');
  	src: url('swebfonts/s-gizmo.eot?#iefix') format('embedded-opentype'),
       	 url('webfonts/ss-gizmo.woff') format('woff'),
         url('webfonts/ss-gizmo.ttf')  format('truetype'),
         url('webfonts/ss-gizmo.svg#SSGizmo') format('svg');
  	font-weight: normal;
  	font-style: normal;
}

/* ============ FONTS ============ */

@font-face {
	font-family:"Roboto";
	src: url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,300;0,400;0,500;0,700;0,900;1,300;1,400;1,500;1,700;1,900&display=swap');}

@font-face {
	font-family:"Roboto Condensed";
	src: url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:wght@300;400;500;600;700;800;900&display=swap');}

/* ============ BASICS  ============ */

body {
	color: #2A2A2A;
	font-size: 15px;
	font-family: "Roboto", "Arial", "Roboto Condensed", "Arial Narrow", sans-serif, normal, condensed;
	line-height: 18px;
	background-color: #FFFFFF;
	font-weight: 400;
	vertical-align: middle;
	font-kerning: normal;
	text-rendering: geometricPrecision;
	font-optical-sizing: auto;
	font-smooth: antialiased;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.acg-blue {color:#134A86; }
.acg-blue-bg {background-color:#134A86; }

img {height: auto; max-width: 100%; display: block;}

.hidden { display: none; }

.left { float: left; }
.right { float: right; }
.center { margin-left: auto; margin-right: auto; display: block; clear: both; }
.clear { clear: both; display: block; font-size: 0; height: 0; line-height: 0; width:100%; overflow: auto; }

::-moz-selection { color: #fff; text-shadow:none; background:#14181A; }
::selection { color: #fff; text-shadow: none; background-color: #14181A; }


*, *::after, *::before {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0;
	margin: 0;
}

:hover {
	-webkit-transition: background-color .4s linear, color .4s linear;
	-moz-transition: background-color .4s linear, color .4s linear;
	-o-transition: background-color .4s linear, color .4s linear;
	-ms-transition: background-color .4s linear, color .4s linear;
	transition: background-color .4s linear, color .4s linear;
}

a {
	padding: 0;
	margin: 0;
	text-decoration: none;
	-webkit-transition: background-color .4s linear, color .4s linear;
	-moz-transition: background-color .4s linear, color .4s linear;
	-o-transition: background-color .4s linear, color .4s linear;
	-ms-transition: background-color .4s linear, color .4s linear;
	transition: background-color .4s linear, color .4s linear;
	color: inherit;
	font-size: inherit;
	line-height: inherit;
}
a:hover,
a:focus {
	text-decoration: none;
	color: #134A86;
	-webkit-transition: background-color .4s linear, color .4s linear;
	-moz-transition: background-color .4s linear, color .4s linear;
	-o-transition: background-color .4s linear, color .4s linear;
	-ms-transition: background-color .4s linear, color .4s linear;
	transition: background-color .4s linear, color .4s linear;
}

a:link, 
a:visited,
a:hover, 
a:active {
	outline: none;
	color: inherit;
} 

a img { 
	border: none; 
	vertical-align: middle;
}

hr {
	width: 100%;
	height: 1px;
	margin: 30px 0px;
	padding: 0;
	display: block;
	border-left: 0;
	border-right: 0;
	border-bottom: 0;
	border-top: 1px solid #7F7F7F;
}

.line   { width: 100%; height: 1px; border-top: 2px solid #cccccc; display: block; }
.line35 { width: 35%; border-top: 2px solid #666666;}
.line50 { width: 50%; border-top: 2px solid #666666;}
.line25 { width: 25%; border-top: 2px solid #666666;}

.in-line { width: 100%; height: 1px; border-top: 1px solid #666666; display: inline; }

/* ============ TIPOGRAFY  ============ */

p {
	font-size: 15px;
	line-height: 18px;
	margin: 0px 0px 8px 0px;
	font-weight: 400;
	vertical-align: baseline;
	font-family: "Roboto", "Arial", sans-serif, normal;
}

h1, h2, h3, h4, h5, h6 {
	margin: 5px 0px 10px;
	font-weight: 400;
	font-family: "Roboto Condensed", "Arial Narrow", "sans-serif", condensed;
	letter-spacing: 1px;
}

h1 {font-size: 100%;}
h2 {font-size: 100%;}
h3 {font-size: 100%;}
h4 {font-size: 100%; font-weight: 500;}
h5 {font-size: 100%; font-weight: 500;}
h6 {font-size: 100%; font-weight: 600; text-transform: uppercase;}

.thin {font-weight: 300;}

b {font-weight: 600; color: inherit; font-size: inherit; line-height: inherit;}
strong {font-weight: 500; color: inherit; font-size: inherit; line-height: inherit;}
u {text-decoration: none; border-bottom: 1px solid; padding-bottom: 1px; font-size: inherit; }
small {font-size: 12px;}
pre { margin-bottom: 10px; }
mark { background-color: #D3F5F5; padding: 0px 4px 2px; line-height: 100%;} 

.narrow { font-family: "Roboto Condensed","Arial Narrow", sans-serif, condensed;}

.textcenter {text-align: center;}
.textleft {text-align: left;}
.textright {text-align: right;}


/* ============ SITE STRUCTURE  ============ */

.site_wrapper {
	width: 100%;
	height: auto;
	margin: 0 auto 0 auto;
	text-align: left;
}

section {
	display: block;
	width: 100%;
	height: auto;
	padding-top: 35px;
	padding-bottom: 35px;
	position: relative;
	float: left;
}
section::before, section::after {clear: both;}


.container_full {
	width: 100%;
	float: left;
	margin: auto auto auto auto;
}
.container {
	width: 1170px;
	margin: auto auto auto auto;
	padding: 0px 10px;
	position: relative;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}

@media screen and (max-width: 319px) { .container { max-width: 240px; } }
@media screen and (min-width: 320px) { .container { max-width: 300px; } }
@media screen and (min-width: 360px) { .container { max-width: 350px; } }
@media screen and (min-width: 400px) { .container { max-width: 380px; } }
@media screen and (min-width: 460px) { .container { max-width: 440px; } }
@media screen and (min-width: 480px) { .container { max-width: 460px; } }
@media screen and (min-width: 520px) { .container { max-width: 500px; } }
@media screen and (min-width: 560px) { .container { max-width: 540px; } }
@media screen and (min-width: 600px) { .container { max-width: 580px; } }
@media screen and (min-width: 640px) { .container { max-width: 620px; } }
@media screen and (min-width: 680px) { .container { max-width: 660px; } }
@media screen and (min-width: 720px) { .container { max-width: 700px; } }
@media screen and (min-width: 760px) { .container { max-width: 740px; } }
@media screen and (min-width: 800px) { .container { max-width: 780px; } }
@media screen and (min-width: 840px) { .container { max-width: 820px; } }
@media screen and (min-width: 880px) { .container { max-width: 860px; } }
@media screen and (min-width: 920px) { .container { max-width: 900px; } }
@media screen and (min-width: 940px) { .container { max-width: 920px; } }
@media screen and (min-width: 980px) { .container { max-width: 960px; } }
@media screen and (min-width: 1020px) { .container { max-width: 1000px; } }

/* ---- columns ---- */

.one_, .one_half, .one_third, .one_fourth, .two_third, .three_fourth, .one_fifth, .one_sixth, .four_fifth, .five_sixth {
	position: relative;
	padding: 10px;
	float: left;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}

.one_ { width: 100%; }
.one_half {width: 50%;}
.one_third {width: 33.33%;}
.two_third {width: 66.66%;}
.one_fourth {width: 25%;}
.three_fourth {width: 75%;}
.one_fifth {width: 20%;}
.four_fifth {width: 80%;}
.one_sixth {width: 16.66%;}
.five_sixth {width: 83.34%;}


 
@media screen and (max-width: 820px) {
	.one_third, .one_fourth, .one_fifth, .one_sixth { width: 50%; }
  	.one_half, .two_third, .three_fourth { width: 100%; } }

@media screen and (max-width: 768px) {
  	.one_third, .one_fourth, .one_fifth, .one_sixth { width: 50%; }
  	.one_half, .two_third, .three_fourth, .four_fifth, .five_sixth { width: 100%; } }

@media screen and (max-width: 600px) {
  	.one_half,.one_third,.one_fourth,.two_third,.three_fourth,.one_fifth,.four_fifth,.one_sixth,.five_sixth 
	{ width: 100%; } }

.last {
	margin-right: 0 !important;
	clear: right;
}

.row { width: 100%; display: table;}
.row::after {content: ""; clear: both; display: table;}

.cell {display: table-cell; padding: 20px;}

@media only screen and (max-width: 600px) {.cell {display: block;width: 100%;}}



/* ============ HEADER  ============ */

.clearheader { position: relative; display: block; width: 100%; height: 80px; background-color: #FFFFFF;}

.header {
	position: relative;
	width: 100%;
	z-index: 100;
	-webkit-transition: height 0.5s;
    -moz-transition: height 0.5s;
    -ms-transition: height 0.5s;
    -o-transition: height 0.5s;
    transition: height 0.5s;
}

.header_wrapper {
	position: relative;
	border-bottom: 1px solid #E0E0E0;
	width: 100%;
	background-color: rgba(255,255,255,1);
	-webkit-box-shadow: 1px 0 5px rgba(0, 0, 0, 0.3);
	-ms-box-shadow: 1px 0 5px rgba(0, 0, 0, 0.3);
	-moz-box-shadow: 1px 0 5px rgba(0, 0, 0, 0.3);
	box-shadow: 1px 0 5px rgba(0, 0, 0, 0.3);
	transition: 0.5s;
}

#sticky {
	position: fixed;
	top: 0;
	width: 100%;
	padding: 20px 10px 19px 10px;
	z-index: 1000;
	-webkit-transition: all .5s ease-in-out;
	-moz-transition: all .5s ease-in-out;
	-o-transition: all .5s ease-in-out;
	-ms-transition: all .5s ease-in-out;
	transition: all .5s ease-in-out;
	scroll-behavior: smooth;
}

.logo {
	width: 45%;
	float: left;
	max-height: 40px;
	vertical-align: middle;
	font-size: 32px;
	line-height: 40px;
	color: #555555;
}
.logo img {
	max-height: 40px;
	max-width: 240px;
	vertical-align: middle;
	padding: 4px 10px 0px;
	opacity: 0.95;
	filter: Alpha(opacity=95); /* IE8 and earlier */
}
.logo img:hover {opacity: 1;}

.main-nav {
	padding-left: 20px;
	width: 55%;
	float: right;
	position: relative;
}

@media screen and (max-width: 980px) {
	.logo img {max-height: 35px;}
	.logo {width: 35%; } 
	.main-nav {width: 65%;}
}

@media screen and (max-width: 900px) {
	#sticky {padding: 15px 10px 10px 10px;}
	.logo {width: 35%; } 
	.main-nav {width: 65%;}
	.clearheader { height: 60px;}
}
@media screen and (max-width: 820px) {
	.main-nav {width: 70%;}
	.logo {width: 30%; padding-left:0; }
	.clearheader { height: 68px;}
}
@media screen and (max-width: 760px) {
	.main-nav {width: 60%;}
	.logo {width: 40%;}
	.logo img { max-height: 40px;}
}

@media screen and (max-width: 600px) {
	.logo {padding-left:0; font-size: 32px; line-height: 40px; width: 60%;}
	.logo img { max-height: 40px; margin-right: 6px;}
	.main-nav {width: 40%;}
	.clearheader { height: 68px;}
}
@media screen and (max-width: 400px) {
	.logo { width: 75%; max-height: 38px; line-height: 38px; padding: 1px 0px;}
	.logo img { max-height: 38px; margin-right: 10px; } 
	.main-nav { width: 25%; max-height: 40px; }
	.clearheader { height: 66px;}
}


/* ============ FOOTER  ============ */

.vert-distance {
	width: 100%;
	height: 40px;
	display: block;
	clear: both;
}

.footer {
	width: 100%;
	min-height: 200px;
	float: left;
	padding: 40px 0px;
	color: #777777;
	background-color: #161616;
}
footer::after, footer::before, 
.copyright::after, .copyright::before
{clear: both;}

.copyright {
	width: 100%;
	float: left;
	background-color: #232323;
	padding-top: 25px;
	padding-bottom: 25px;
	color: #909090;
	text-align: center;
	line-height: 20px;
	border-top: thin solid #1F1F1F;
}
.copyright small { font-size: 13px; }

.copyright a:hover {
	color: #FFFFFF;
}

.copyright-fixed {
	position: fixed;
	bottom: 0; left:0; 
	width: 100%;
	float: left;
	background-color: rgba(7,8,9,0.70);
	padding-top: 10px;
	padding-bottom: 15px;
	color: #787A7B;
	text-align: center;
	line-height: 20px;
	border-top: thin solid #363A40;
}
.copyright-small {
	position: relative;
	bottom: 0;
	left: 0;
	max-height: 36px;
	width: 100%;
	float: left;
	background-color: #030303;
	padding-top: 6px;
	padding-bottom: 10px;
	font-size: 14px;
	color: #787A7B;
	text-align: center;
	line-height: 18px;
	border-top: thin solid #363A40;
}
.copyright img {
	height: 18px; 
	display: inline-block; 
	margin:0px 2px 0px 2px; 
	vertical-align: text-bottom; 
	mix-blend-mode:luminosity;}

/* scroll up */

.to-top {
	z-index: 10;
	width: 36px;
	height: 36px;
	text-indent: -99999px;
	position: fixed;
	bottom: 15px;
	right: 20px;
	cursor: pointer;
	overflow: auto;
	background-color: #4B4B4B;
	display: block;
	background-image: url(../img/icons/arrow-up.png);
	background-repeat: no-repeat;
	background-position: 50% 50%;
	opacity: 0.6;
	-webkit-box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.5);
	box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.5);
	border: 1px solid #363A40;
	border-radius: 3px;
	-webkit-transition: all .5s ease-in-out;
	-moz-transition: all .5s ease-in-out;
	-o-transition: all .5s ease-in-out;
	-ms-transition: all .5s ease-in-out;
	transition: all .5s ease-in-out;
	scroll-behavior: smooth;
}

.to-top:hover {
	background-color: #134A86;
	opacity: 1;
	-ms-box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.4);
	-webkit-box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.4);
	box-shadow: 0px 0px 3px 0px rgba(0,0,0,0.4);
	border: 1px solid #134A86;
}	

@media screen and (max-width: 480px) { 
	.to-top {width: 24px; height: 24px; bottom: 10px; right: 10px;} }


/* titles pages */

.title-bg-home {
	width: 100%;
	height: auto;
	display: block;
	min-height: 300px;
	padding-top: 10px;
}

.title-page {
	display: block;
	position: relative;
	width: 100%;
	height: auto;
	padding: 10px 0px 10px;
	background-color: #134A86;
	color: #FFFFFF;	
}
.title-page .container { 
	min-height: 50px;
	height: auto;
}

.title-page .container h2 {
	display: inline-block;
	font-family: "Roboto Condensed", "Arial Narrow", "sans-serif", condensed;
	letter-spacing: 1px;
	font-size: 24px;
	line-height: 26px;
	font-weight: 400;
	vertical-align: middle;
	padding: 0px 10px;
	margin: auto;
	-webkit-transform: translateY(50%);
	-ms-transform: translateY(50%);
	transform: translateY(50%);
}

@media screen and (max-width: 600px) {
	.title-page .container { min-height: 40px; height: auto;}
	.title-page .container h2 { line-height: 26px; font-size: 22px; white-space: normal; transform: translateY(25%); } }


/* ============ CONTENT  ============ */


.content {
	width: 100%;
	height: auto;
	padding-top: 20px;
	padding-bottom: 30px;
}
.content::after {clear: both;}

.box {
	width: 100%;
	height: auto;
	display: block;
}

.error-page { text-align: center; margin: auto; padding: 40px; min-height: 340px; }
.error-page div {
	font-size: 140px;
	line-height: 160px;
	color: #134A86;
	font-weight: 900;
	display: block;
	margin-bottom: 30px;
}
.error-page p { font-size: 18px; line-height: 22px;}
.error-page a { color: #134A86;}

@media screen and (max-width: 480px) {  
	.error-page { padding: 20px; }
	.error-page div { font-size: 100px; line-height: 120px;  }
}


/* buttons */

.btn-small-blue {
	position: relative;
	font-size: 12px;
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 1px;
	line-height: 16px;
	padding: 6px 10px 7px;
	text-align: center;
	border: 1px solid;
	border-radius: 5px;
	text-decoration: none;
	background-color: #134A86; 
	color: #FFFFFF;
}


.btn {
	position: relative;
	font-size: 13px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 1px;
	line-height: 18px;
	padding: 6px 10px 7px;
	text-align: center;
	border: 1px solid;
	border-radius: 5px;
	text-decoration: none;
}

.btn-blue {
	vertical-align: middle;
	-webkit-transform: perspective(1px) translateZ(0);
	transform: perspective(1px) translateZ(0);
	box-shadow: 0 0 1px rgba(0, 0, 0, 0);
	position: relative;
	background-color: rgba(225,225,225,0.00);
	-webkit-transition-property: color;
	-ms-transition-property: color;
	transition-property: color;
	-webkit-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
	transition-duration: 0.3s;	
}

.btn-blue::before, .btn-blue::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	color: #FFFFFF;
	border-radius: 5px;
	background-color: #134A86;
	-webkit-transform: scaleX(0);
	-ms-transform: scaleX(0);
	transform: scaleX(0);
	-webkit-transform-origin: 50%;
	-ms-transform-origin: 50%;
	transform-origin: 50%;
	-webkit-transition-property: transform;
	-ms-transition-property: transform;
	transition-property: transform;
	-webkit-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
	transition-duration: 0.3s;
	-webkit-transition-timing-function: ease-out;
	-ms-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
}
.btn-blue:hover, .btn-blue:focus, .btn-blue:active, .btn-blue:visited, .btn-blue:visited::after{color: #FFFFFF;}
.btn-blue:hover::before, .btn-blue:focus::before, .btn-blue:active::before, .btn-blue:visited::before {
  	-webkit-transform: scaleX(1);
	-ms-transform: scaleX(1);
  	transform: scaleX(1);
}



.btn-black {
	vertical-align: middle;
	-webkit-transform: perspective(1px) translateZ(0);
	transform: perspective(1px) translateZ(0);
	box-shadow: 0 0 1px rgba(0, 0, 0, 0);
	position: relative;
	background-color: rgba(225,225,225,0.00);
	-webkit-transition-property: color;
	-ms-transition-property: color;
	transition-property: color;
	-webkit-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
	transition-duration: 0.3s;	
}

.btn-black::before, .btn-black:before {
	content: "";
  	position: absolute;
  	z-index: -1;
 	top: 0;
 	bottom: 0;
 	left: 0;
  	right: 0;
 	background: #060808;
  	-webkit-transform: scaleX(0);
	-ms-transform: scaleX(0);
  	transform: scaleX(0);
  	-webkit-transform-origin: 50%;
	-ms-transform-origin: 50%;
  	transform-origin: 50%;
  	-webkit-transition-property: transform;
	-ms-transition-property: transform;
  	transition-property: transform;
  	-webkit-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
  	transition-duration: 0.3s;
  	-webkit-transition-timing-function: ease-out;
	-ms-transition-timing-function: ease-out;
  	transition-timing-function: ease-out;
}
.btn-black:hover, .btn-black:focus, .btn-black:active {color: white;}
.btn-black:hover:before, .btn-black:focus:before, .btn-black:active:before {
  	-webkit-transform: scaleX(1);
	-ms-transform: scaleX(1);
  	transform: scaleX(1);
}


.btn-white {
	color: white;
	vertical-align: middle;
	-webkit-transform: perspective(1px) translateZ(0);
	transform: perspective(1px) translateZ(0);
	box-shadow: 0 0 1px rgba(0, 0, 0, 0);
	position: relative;
	background-color: rgba(225,225,225,0.00);
	-webkit-transition-property: color;
	-ms-transition-property: color;
	transition-property: color;
	-webkit-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
	transition-duration: 0.3s;
}
.btn-white::before, .btn-white:before {
	content: "";
	position: absolute;
	z-index: -1;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: #FFFFFF;
	-webkit-transform: scaleX(0);
	-ms-transform: scaleX(0);
	transform: scaleX(0);
	-webkit-transform-origin: 50%;
	-ms-transform-origin: 50%;
	transform-origin: 50%;
	-webkit-transition-property: transform;
	-ms-transition-property: transform;
	transition-property: transform;
	-webkit-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
	transition-duration: 0.3s;
	-webkit-transition-timing-function: ease-out;
	-ms-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
}
.btn-white:hover, .btn-white:focus, .btn-white:active {color: black;}
.btn-white:hover:before, .btn-white:focus:before, .btn-white:active:before {
  	-webkit-transform: scaleX(1);
	-ms-transform: scaleX(1);
  	transform: scaleX(1);
}

.btn-grey {
	vertical-align: middle;
	-webkit-transform: perspective(1px) translateZ(0);
	transform: perspective(1px) translateZ(0);
	box-shadow: 0 0 1px rgba(0, 0, 0, 0);
	position: relative;
	background-color: rgba(225,225,225,0.00);
	-webkit-transition-property: color;
	-ms-transition-property: color;
	transition-property: color;
	-webkit-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
	transition-duration: 0.3s;	
}

.btn-grey::before, .btn-grey:before {
	content: "";
  	position: absolute;
  	z-index: -1;
 	top: 0;
 	bottom: 0;
 	left: 0;
  	right: 0;
 	background: #6B6B6B;
  	-webkit-transform: scaleX(0);
	-ms-transform: scaleX(0);
  	transform: scaleX(0);
  	-webkit-transform-origin: 50%;
	-ms-transform-origin: 50%;
  	transform-origin: 50%;
  	-webkit-transition-property: transform;
	-ms-transition-property: transform;
  	transition-property: transform;
  	-webkit-transition-duration: 0.3s;
	-ms-transition-duration: 0.3s;
  	transition-duration: 0.3s;
  	-webkit-transition-timing-function: ease-out;
	-ms-transition-timing-function: ease-out;
  	transition-timing-function: ease-out;
}
.btn-grey:hover, .btn-grey:focus, .btn-grey:active {color: white;}
.btn-grey:hover:before, .btn-grey:focus:before, .btn-grey:active:before {
  	-webkit-transform: scaleX(1);
	-ms-transform: scaleX(1);
  	transform: scaleX(1);
}

	
/* overlay images */

.grayfilter {
	-webkit-filter: grayscale(100%); /* Safari 6.0 - 9.0 */
  	filter: grayscale(100%);	
}

.image {
	width: 100%;
	height: auto;
	display: block;
	transition: transform .4s;	
}
.image:hover {
	transform: scale(1.1);	
}
.imageless {
	width: 100%;
	height: auto;
	display: block;
	transition: transform .4s;	
}
.imageless:hover {
	transform: scale(0.8);	
}

.img-wrap {
  	position: relative;
  	width: 100%;
	overflow: hidden;
}

.img-mask {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100%;
  width: 100%;
  transition: .5s ease;
  background-color: rgba(0,0,0,0.05);
}

.img-wrap:hover .img-mask {
  background-color: rgba(0,0,0,0.1);
}

.overlay-zoom {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: rgba(0,0,0,0);
	overflow: hidden;
	width: 100%;
	height: 100%;
	-webkit-transform: scale(0.2);
  	-ms-transform: scale(0.2);
 	transform: scale(0.2);
	-webkit-transition: .4s ease-out;
	-ms-transition: .4s ease-out;
	transition: .3s ease-out;
}

.img-wrap:hover .overlay-zoom {
  	-webkit-transform: scale(1);
  	-ms-transform: scale(1);
  	transform: scale(1);
	background-color: rgba(0,0,0,0.4);
	
}

.overlay-top {
  	position: absolute;
  	bottom: 100%;
  	left: 0;
  	right: 0;
  	background-color: rgba(0,0,0,0.6);
  	overflow: hidden;
  	width: 100%;
  	height: 0;
  	-webkit-transition: .4s ease-in-out;
	-ms-transition: .4s ease-in-out;
	transition: .4s ease-in-out;
}

.img-wrap:hover .overlay-top {
  	height: 100%;
	bottom: 0;
}

.overlay-left {
  	position: absolute;
  	bottom: 0;
  	left: 0;
  	right: 0;
  	background-color: rgba(0,0,0,0.6);
  	overflow: hidden;
  	width: 0;
  	height: 100%;
  	-webkit-transition: .4s ease-out;
	-ms-transition: .4s ease-out;
	transition: .4s ease-out;
}

.img-wrap:hover .overlay-left {
  	width: 100%;
	transition-delay: 0.21s;
}

.overlay-bottom {
  	position: absolute;
  	bottom: 0;
  	left: 0;
  	right: 0;
  	background-color: rgba(0,0,0,0.6);
  	overflow: hidden;
  	width: 100%;
  	height: 0;
  	-webkit-transition: .4s ease-in-out;
	-ms-transition: .4s ease-in-out;
	transition: .4s ease-in-out;
}

.img-wrap:hover .overlay-bottom {
  	height: 100%;
}
.overlay-bottom-title {
  	position: absolute;
  	bottom: 0;
  	left: 0;
  	right: 0;
  	background-color: rgba(0,0,0,0.6);
  	overflow: hidden;
  	width: 100%;
  	height: 0;
  	-webkit-transition: .3s ease;
	-ms-transition: .3s ease;
	transition: .3s ease;
}

.img-wrap:hover .overlay-bottom-title {
  	height: 30%;
}
.overlay-bottom-push {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: rgba(255,255,255,0.01);
	overflow: hidden;
	width: 100%;
	height: 60%;
	-webkit-transition: .3s ease;
	-ms-transition: .3s ease;
	transition: .3s ease;
}

.img-wrap:hover .overlay-bottom-push {
  	height: 100%;
}
.over-text-50 {
  	color: white;
  	font-size: 20px;
  	position: absolute;
  	top: 50%;
  	left: 50%;
  	-webkit-transform: translate(-50%, -50%);
  	-ms-transform: translate(-50%, -50%);
  	transform: translate(-50%, -50%);
  	text-align: center;
	white-space: nowrap;
}

.over-text-push {
  	color: white;
  	position: absolute;
  	top: 50%;
  	left: 50%;
  	-webkit-transform: translate(-50%, -50%);
  	-ms-transform: translate(-50%, -50%);
  	transform: translate(-50%, -50%);
  	text-align: center;
	white-space: nowrap;
}

.over-icon {
	color: white;
	font-size: 50px;
	font-weight: lighter;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 50px;
	height: 50px;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	text-align: center;
	vertical-align: middle;
	white-space: nowrap;
	opacity: 0.9;
}
.over-icon:hover {opacity: 1;}

/* colors */

.bg-blue { background-color: #2D5D97;}
.bg-bluem { background-color: #4D7AB0;}
.bg-bluelight { background-color: #DAE3EE;}

.bg-greydark { background-color: #222222;}
.bg-grey-mdld { background-color: #4D4D4D;}
.bg-grey-mdll { background-color: #9F9F9F;}
.bg-greylight { background-color: #D8D8D8;}
.bg-greywhite { background-color:#ECECEC;}

.bg-red {background-color: #B40000;}

.white {color:white;}


