/*
--------------------------------------------------------------------------------------

	Various components
	components.various.css

--------------------------------------------------------------------------------------
*/




/*
-------------------------------------------
	Fonts
-------------------------------------------
*/


@font-face {
    font-family: 'moriston-light';
    src: url('fonts/moriston-light.eot');
    src: url('fonts/moriston-light.eot?#iefix') format('embedded-opentype'),
         url('fonts/moriston-light.woff2') format('woff2'),
         url('fonts/moriston-light.woff') format('woff'),
         url('fonts/moriston-light.ttf') format('truetype'),
         url('fonts/moriston-light.svg#moriston-light') format('svg');
    font-weight: normal;
    font-style: normal;
}


@font-face {
    font-family: 'moriston-bold';
    src: url('fonts/moriston-bold.eot');
    src: url('fonts/moriston-bold.eot?#iefix') format('embedded-opentype'),
         url('fonts/moriston-bold.woff2') format('woff2'),
         url('fonts/moriston-bold.woff') format('woff'),
         url('fonts/moriston-bold.ttf') format('truetype'),
         url('fonts/moriston-bold.svg#moriston-bold') format('svg');
    font-weight: normal;
    font-style: normal;
}



/*
-------------------------------------------
	Title header
-------------------------------------------
*/


.title-header {
	background-color: #f5f5f5;
	color: #000;
	padding: 50px 0;
	margin-bottom: 0;
	text-align: center;
}

.title-header h1 {margin:0;}



/*
-------------------------------------------
	Text
-------------------------------------------
*/

.sub-title {
	max-width: 500px;
	margin:0 auto;
	margin-bottom: 40px;
	text-align: center;
}



/*
-------------------------------------------
	Lists
-------------------------------------------
*/


.list a {text-decoration: none;}

.list {
	margin:0 0 25px 0; 
	padding:0;
	list-style:none;
	list-style-type:none;
}

.list ul {margin:10px 0 10px 25px;}

.list li {
	list-style:none;
	list-style-type:none;
	padding-left:0;
	margin-left: 0;
	line-height:150%;
	margin-bottom: 5px;
}

/* cols, inline */

.list--2-cols {
	-moz-column-count:2;
	-webkit-column-count:2;
	column-count: 2;
	margin-bottom: 20px;
}

.list--2-cols li {
	-webkit-column-break-inside: avoid;
	page-break-inside: avoid;
	break-inside: avoid;
}

.list--inline li {
	display: inline-block;
	margin-right: 5px;
}


/* bullets */

.list--bullets {
	margin:0 0 25px 25px;
	list-style-type: none;
	padding: 0;
}

.list--bullets ul {margin:10px 0 10px 25px;}

.list--bullets li {
	margin-bottom: 5px;
	position: relative;
	padding-left: 20px;
}

.list--bullets li:before {
	content: "\2022";
	color: #000;
	background-color: transparent;
	font-size: 25px;
	position: absolute;
	left: 0;
	top: 0;
}



/*
-------------------------------------------
	Images
-------------------------------------------
*/


/* hover effect */

a img {
	-webkit-transition: all .3s ease-in-out;
    -moz-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

a:hover img {opacity: 0.8;}


/* slideshow */

.slideshow {
	position: relative;
	margin-bottom: 0;
}

.slideshow__images,
.slideshow__images li {
	margin:0;
	padding: 0;
	list-style: none;
}

.slideshow__heading {
	position: absolute;
	bottom: 70px;
	left: 0;
	font-family: 'moriston-light', helvetica, arial, sans-serif;
	font-size: 3em;
	width: 100%;
	color: #fff;
	background-color: transparent;
	text-align: center;
	margin: 0;
	padding: 0;
	z-index: 99;
}

.slideshow__images {
	position: relative;
	list-style: none;
	overflow: hidden;
	width: 100%;
	padding: 0;
	margin: 0;
}

.slideshow__images li {
	-webkit-backface-visibility: hidden;
	position: absolute;
	display: none;
	width: 100%;
	left: 0;
	top: 0;
}

.slideshow__images li:first-child {
	position: relative;
	display: block;
	float: left;
}

.slideshow__images img {
	display: block;
	height: auto;
	float: left;
	width: 100%;
	border: 0;
}


/* gallery */

.gallery {text-align: center;}

.gallery li a {display: block;}

.gallery li a:focus {
	border: 0;
	outline: none;
}

.gallery__list img {border-radius: 4px;}




/* usp icons */

.usp-icon {margin-bottom: 10px;}

.usp-icon__text {
	font-size: .9em;
	line-height: 1.2em;
}



/*
-------------------------------------------
	Products
-------------------------------------------
*/

.products a {
	display: block;
	text-decoration: none;
}

.products h2 {color: #032D5B;}

.products a:hover h2 {color: #000;}

.products img {border-radius: 4px;}


/*
-------------------------------------------
	Squares
-------------------------------------------
*/

.squares-set {
	border-bottom: 1px solid #eee;
	margin-bottom: 60px;
}

.square {
	display: table;
	width: 100%;
	margin-bottom: 0;
}

.square__pic img {display: block;}

.square__pic,
.square__text {
	display: table-cell;
	width: 50%;
	vertical-align: middle;
}

.square__pic {position: relative;}

.square__message {
	max-width: 500px;
	margin:0 auto;
	padding: 30px;
	text-align: center;
}

.square__message p:last-child {margin-bottom: 0;}

.square__caption {
	position: absolute;
	bottom: 0;
	left: 0;
	margin: 0;
	padding: 15px 0 15px 40px;
	display: inline-block;
	background: url(icons/info.png);
	background: url(icons/info.svg), linear-gradient(transparent, transparent);
	background-position: 12px 10px;
	background-repeat: no-repeat;
	line-height: 100%;
	color: transparent;
	font-size: .9em;
	opacity: 0.6;
}

.square__caption:hover,
.square__caption:focus {
	color:#fff;
	background-color: transparent;
	opacity: 1;
}



/*
-------------------------------------------
	Quotes
-------------------------------------------
*/

.quote {text-align: center;}

.quote p {
	font-family: 'moriston-light', helvetica, arial, sans-serif;
	font-size: 2.2em;
	color: #000;
	background-color: transparent;
	line-height: 1.3em;
	max-width: 700px;
	margin:0 auto;
	padding: 55px 0 15px 0;
	background: url(icons/quote.png);
	background: url(icons/quote.svg), linear-gradient(transparent, transparent);
	background-position: top center;
	background-repeat: no-repeat;
}

.quote cite {
	font-size: .9em;
	font-style: normal;
}





/*
-------------------------------------------
	Look inside
-------------------------------------------
*/


/* Responsive embedding
   http://embedresponsively.com */

.embed-container {
	position: relative;
	padding-bottom: 56.25%; 
	height: 0; 
	overflow: hidden; 
	max-width: 100%;
}

.embed-container iframe, 
.embed-container object, 
.embed-container embed {
	position: absolute; 
	top: 0; 
	left: 0;
	width: 100%; 
	height: 100%;
}

.scrolloff {pointer-events: none;} /* see js */




@media 
only screen and (max-width: 768px), 
only screen and (max-device-width: 768px) {


.title-header {padding: 40px 0;}

.slideshow__heading {
	font-size:2em;
	bottom: 40px;
}


} /* end media query */



@media 
only screen and (max-width: 600px), 
only screen and (max-device-width: 600px) {

.title-header {padding: 30px 0;}

.title-header h1 {font-size: 1.8em;}

.slideshow__heading {
	font-size:1em;
	font-weight: bold;
	bottom: 25px;
}

.quote p {font-size: 1.8em;}

.square__pic,
.square__text {
	display: block;
	width: 100%;
}

.square__message {
	max-width: none;
	margin:0 auto;
	padding: 30px;
	text-align: left;
}

.usp-icon {max-width: 80px;}


} /* end media query */










