/*
Theme Name: IPCS
Theme URI: http://www.beamtwenty3.co.uk
Description: Wordpress Theme By Neil Brown for IPCS
Version: 1.0
Author: Neil Brown
Author URI: http://www.beamtwenty3.co.uk
*/

/* #Reset & Basics (Inspired by E. Meyers) */

	html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
		margin: 0;
		padding: 0;
		border: 0;
		font-size: 100%;
		font: inherit;
		vertical-align: baseline; }
	article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
		display: block; }
	body {
		line-height: 1; }
	ol, ul {
		list-style: none; }
	blockquote, q {
		quotes: none; }
	blockquote:before, blockquote:after,
	q:before, q:after {
		content: '';
		content: none; }
	table {
		border-collapse: collapse;
		border-spacing: 0; }


/* #Basic Styles */

body {
	background: #fff;
	font: 14px/21px 'Roboto', Helvetica, Arial, sans-serif;
	color: #444;
	-webkit-font-smoothing: antialiased; /* Fix for webkit rendering */
	-webkit-text-size-adjust: 100%;
 }


/* #Typography */

h1, h2, h3, h4, h5, h6 {
	color: #164e9a;
	font-weight: 300;
}

h1 { 
	font-size: 30px;
	line-height: 50px;
	margin-bottom: 14px;
}

h2 { font-size: 30px;
	line-height: 40px;
	margin: 20px 0px 20px 0px;
}

h3 { 
	font-size: 28px;
	line-height: 34px;
	margin: 20px 0px 20px 0px;
}

h4 { font-size: 21px; line-height: 30px; margin-bottom: 4px; }
h5 { font-size: 17px; line-height: 24px; }
h6 { font-size: 14px; line-height: 21px; }

h1.main-title {
	background: #f47b36;
	color: #fff;
	padding: 7px 10px 7px 15px;	
	margin-bottom: 30px;
}

p { 
	font-size: 17px;
	line-height: 28px;
	margin: 0 0 16px 0;
	color: #525252;
}

.ipcs-home p {
	font-size: 22px;
	line-height: 40px;
	text-align: center;
}

sub {
    vertical-align: sub;
    font-size: smaller;
}

sup {
    vertical-align: super;
    font-size: smaller;
}


em { font-style: italic; }
strong { font-weight: bold;}
small { font-size: 80%; }

/*	Blockquotes  */

blockquote, blockquote p { font-size: 17px; line-height: 24px; color: #777; font-style: italic; }
blockquote { margin: 0 0 20px; padding: 9px 20px 0 19px; border-left: 1px solid #ddd; }
blockquote cite { display: block; font-size: 12px; color: #555; }
blockquote cite:before { content: "\2014 \0020"; }
blockquote cite a, blockquote cite a:visited, blockquote cite a:visited { color: #555; }

hr { border: solid #ddd; border-width: 1px 0 0; clear: both; margin: 10px 0 30px; height: 0; }


/* #Links */

a, a:visited { 
	color: #f47b36;
	text-decoration: none;
	outline: 0;
	-webkit-transition: all .1s linear;
	-moz-transition: all .1s linear;
	-o-transition: all .1s linear;
	-ms-transition: all .1s linear;
	transition: all .1s linear;
}

a:hover, a:focus { 
	color: #666;
	text-decoration: none;
}



/* #Lists */

ul, ol { margin-bottom: 20px; }
ul { list-style: none outside; }
ol { list-style: decimal; }

li {
	font-size: 16px;
	line-height: 30px;
	margin: 0 0 4px 0;
	color: #525252;
	list-style: none;		
}

.main-content li:before {    
	font-family: 'FontAwesome';
	content: '\F111';
	margin:0 10px 0 0;
	color: #164e9a;
	font-size: 9px;
}

ul.sitemap li {
	list-style: none;
}



ul.children {
	margin: 20px 0px 20px 20px;
}

/* Tables */

.tablepress>*+tbody>*>*, .tablepress>tbody>*~*>*, .tablepress>tfoot>*>* {
	border-top: 0px solid var(--border-color);
}

td {
	font-weight: 600 !important;
}

.tablepress>:not(caption)>*>* {
	padding: 15px;
}

table {
	margin: 40px 0px 40px 0px !important;
}

.tablepress>:where(thead,tfoot)>*>th {
	background-color: #164e9a;
	color: #fff;
	font-size: 16px;
}


/* #Images */

img {
	max-width: 100%;
	height: auto;
}

/* iFrames */
	
.videoWrapper {
	position: relative;
	padding-bottom: 80%; /* 16:9 */
	padding-top: 25px;
	height: 0;
	z-index: 1;
	margin-bottom: 10px;
}

.videoWrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


/* Buttons */

.button,
button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
  display: inline-block;
  height: 38px;
  padding: 0 30px;
  color: #555;
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  line-height: 38px;
  letter-spacing: .1rem;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  background-color: transparent;
  border-radius: 4px;
  border: 1px solid #bbb;
  cursor: pointer;
  box-sizing: border-box; }
.button:hover,
button:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover,
.button:focus,
button:focus,
input[type="submit"]:focus,
input[type="reset"]:focus,
input[type="button"]:focus {
  color: #333;
  border-color: #888;
  outline: 0; }
.button.button-primary,
button.button-primary,
input[type="submit"].button-primary,
input[type="reset"].button-primary,
input[type="button"].button-primary {
  color: #FFF;
  background-color: #33C3F0;
  border-color: #33C3F0; }
.button.button-primary:hover,
button.button-primary:hover,
input[type="submit"].button-primary:hover,
input[type="reset"].button-primary:hover,
input[type="button"].button-primary:hover,
.button.button-primary:focus,
button.button-primary:focus,
input[type="submit"].button-primary:focus,
input[type="reset"].button-primary:focus,
input[type="button"].button-primary:focus {
  color: #FFF;
  background-color: #1EAEDB;
  border-color: #1EAEDB; }


/* Forms */

input[type="email"],
input[type="number"],
input[type="search"],
input[type="text"],
input[type="tel"],
input[type="url"],
input[type="password"],
textarea,
select {
  height: 38px;
  padding: 6px 10px; /* The 6px vertically centers text on FF, ignored by Webkit */
  background-color: #fff;
  border: 1px solid #D1D1D1;
  border-radius: 4px;
  box-shadow: none;
  box-sizing: border-box; }
/* Removes awkward default styles on some inputs for iOS */
input[type="email"],
input[type="number"],
input[type="search"],
input[type="text"],
input[type="tel"],
input[type="url"],
input[type="password"],
textarea {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none; }
textarea {
  min-height: 65px;
  padding-top: 6px;
  padding-bottom: 6px; }
input[type="email"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
input[type="text"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
  border: 1px solid #33C3F0;
  outline: 0; }
label,
legend {
  display: block;
  margin-bottom: .5rem;
  font-weight: 600; }
fieldset {
  padding: 0;
  border-width: 0; }
input[type="checkbox"],
input[type="radio"] {
  display: inline; }
label > .label-body {
  display: inline-block;
  margin-left: .5rem;
  font-weight: normal; }
  
  
/* Top Nav */

nav.top-nav {
	width: 100%;
	margin: 0 auto;
	background: #164e9a;
	text-align: right;
	border-bottom: solid 2px #f47b36;
}

nav.top-nav p {
	color: #fff;
	margin: 10px 0px 10px 0px;
}

nav.top-nav a:link, nav.top-nav a:visited {
	color: #fff;
	text-decoration: none;
}

nav.top-nav a:hover, nav.top-nav a:focus {
	color: #fff;
	text-decoration: underline;
}

nav.top-nav .fa-phone {
	margin-left: 20px;
}
 
  
/* Header */

header {
	width: 100%;
	margin: 0 auto;
	padding: 10px 0px 0px 0px;
	border-bottom: solid 2px #f47b36;
}

header h1 {
	font-size: 18px;
	line-height: 22px;
	text-align: right;
	margin-top: 15px;
}

/* Slides */

.container.slides {
	border-bottom: solid 2px #f47b36;
	height: 290px;
	overflow: hidden;
}

.slideshow {
	width: 75%;
	float: left;
}

.banner {
	width: 75%;
	float: left;
}

.banner img {
	width: 100%;
}

.slide-nav .eight.columns {
	text-align: center;
}

h2.prev, h2.next {
	cursor: pointer;
}

h2.prev:hover, h2.next:hover {
	color: #f47b36;
}

/* Home Page */

.four.columns.home-links {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	border: solid 1px #ccc;
	margin-bottom: 20px;
	-webkit-transition: all .1s linear;
	-moz-transition: all .1s linear;
	-o-transition: all .1s linear;
	-ms-transition: all .1s linear;
	transition: all .1s linear;
}

.four.columns.home-links:hover {
	border: solid 1px #f47b36;
}

.home-links-products {
	width: 100%;
	margin: 0px 0px 20px 0px;
	text-align: center;
	position: relative;
}

.home-links-products img {
	display: block;
}

.product-hover {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
}

.product-hover {
	opacity:0;
	-ms-filter: "progid: DXImageTransform.Microsoft.Alpha(Opacity=0)";
	filter:alpha(opacity=0); /* For IE8 and earlier */
	-webkit-transition: all .2s linear;
	-moz-transition: all .2s linear;
	-o-transition: all .2s linear;
	-ms-transition: all .2s linear;
	transition: all .2s linear;
	background: rgb(245, 245,245);
	background: rgba(255, 255, 255, 0.80);
	-moz-transform: rotate(0);
}

.product-hover:hover{
	opacity:1.0;
	filter:alpha(opacity=100); /* For IE8 and earlier */
	cursor: pointer;
	-moz-transform: rotate(0);
}

.product-text {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}

h3.product-text {
	font-size: 24px;
	line-height: 40px;
	font-weight: 300;
	margin: 0px;
	text-align: center;	
}

/* Contact Page */

.contact h2 {
	font-size: 24px;
	line-height: 36px;
	margin: 10px 0px 10px 0px; 
}

.contact p {
	margin: 0;
}

.fa-envelope, .fa-phone {
	width: 20px;
}

.home-links img {
	display: block;
}

/* Partners */

.metsch {
	text-align: center;
}


.specification ul {
	display: inline-block;
	width: 100%;
	margin: 0px 0px 20px 0px;
	border-bottom: 1px solid #f0f0f0;
}

.specification li {
	float: left;
	font-size: 12px;
	line-height: 28px;
	font-weight: bold;
	padding: 4px 0px 6px 0px;
	list-style: none;
	margin: 0;
}

.specification li.col1 {
	width: 50%;

}

.specification li.col2 {
	width: 50%;
	text-align: left;
}

.specification li.col1a {
	width: 33%;

}

.specification li.col2a {
	width: 33%;
	text-align: left;
}

.specification li.col3a {
	width: 33%;
	text-align: left;
}

.specification li.col1b {
	width: 16%;

}

.specification li.col2b {
	width: 16%;
	text-align: left;
}

.specification li.col3b {
	width: 16%;
	text-align: left;
}

.specification li.col4b {
	width: 16%;
	text-align: left;
}

.specification li.col5b {
	width: 16%;
	text-align: left;
}

.specification li.col6b {
	width: 16%;
	text-align: left;
}

.specification li.col1c {
	width: 32%;

}

.specification li.col2c {
	width: 32%;
	text-align: left;
}

.specification li.col3c {
	width: 32%;
	text-align: left;
}



.specification li.col1e {
	width: 10%;
	text-align: left;
}

.specification li.col2e {
	width: 10%;
	text-align: left;
}

.specification li.col3e {
	width: 10%;
	text-align: left;
}

.specification li.col4e {
	width: 10%;
	text-align: left;
}

.specification li.col5e {
	width: 10%;
	text-align: left;
}

.specification li.col6e {
	width: 10%;
	text-align: left;
}

.specification li.col7e {
	width: 10%;
	text-align: left;
}

.specification li.col8e {
	width: 10%;
	text-align: left;
}

.specification li.col9e {
	width: 10%;
	text-align: left;
}

.specification li.col10e {
	width: 10%;
	text-align: left;
}


li.orange {
	color: #f47b36;
	margin: 10px 0px 0px 0px;
	font-size: 20px;
	font-weight: normal;	
}

.specification h2 {
	margin: 30px 0px 30px 0px;
}

.specification li.col1c {
	width: 32%;

}


.specification li.col1d {
	width: 32%;

}




/* Main Navigation */


#main-nav {
	width: 25%;
	float: left;
	padding: 0px;
	margin: 0px;
	background: #164e9a;
	height: 500px;
}


#main-nav ul {
	list-style: none;
	margin: 0px;
	padding: 0px;
	width: 100%;  
}

#main-nav li {
	font-size: 18px;
	line-height: 27px;
	padding: 0px;
	margin: 0px;
	font-weight: normal;
	list-style: none;
}

#main-nav a {
	text-decoration: none;
	display: block;
	padding: 15px;
	border-bottom: solid 1px #5577ca;
}

#main-nav a:link,
#main-nav a:visited {
	color: #fff;
	-webkit-transition: all .1s linear;
	-moz-transition: all .1s linear;
	-o-transition: all .1s linear;
	-ms-transition: all .1s linear;
	transition: all .1s linear;
}

#main-nav a:hover {
	color: #fff;
	background: #f47b36;
}



/* Footer */

footer {
	width: 100%;
	margin: 20px auto 0 auto;
	background: #164e9a;
	text-align: center;
	padding-top: 20px;
	border-top: solid 2px #f47b36;
}

footer p {
	font-size: 14px;
	line-height: 21px;
	margin-bottom: 14px;
	color: #fff;
}

footer a:link, footer a:visited {
	color: #fff;
	margin: 0px 5px 0px 5px;
	-webkit-transition: all .1s linear;
	-moz-transition: all .1s linear;
	-o-transition: all .1s linear;
	-ms-transition: all .1s linear;
	transition: all .1s linear;
}

footer a:hover {
	color: #f47b36;
}

footer .fa-envelope, footer .fa-phone {
    width: auto;;
}


/* =WordPress Core  */

.alignnone {
    margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
    display: block;
    margin: 5px auto 5px auto;
}

.alignright {
    float:right;
    margin: 5px 0 20px 20px;
}

.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

.aligncenter {
    display: block;
    margin: 5px auto 5px auto;
}

a img.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

a img.alignnone {
    margin: 5px 20px 20px 0;
}

a img.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto
}

.wp-caption {
    background: #fff;
    border: 1px solid #f0f0f0;
    max-width: 96%; /* Image does not overflow the content area */
    padding: 5px 3px 10px;
    text-align: center;
}

.wp-caption.alignnone {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
    margin: 5px 0 20px 20px;
}

.wp-caption img {
    border: 0 none;
    height: auto;
    margin: 0;
    max-width: 98.5%;
    padding: 0;
    width: auto;
}

.wp-caption p.wp-caption-text {
    font-size: 11px;
    line-height: 17px;
    margin: 0;
    padding: 0 4px 5px;
}



div.wpcf7 {
	margin: 0px 0px 0px 0px !important;
	padding: 0;
}

div.wpcf7-mail-sent-ok {
	border: 0px solid #398f14 !important;
	color: #666 !important;
}

div.wpcf7-mail-sent-ng {
	border: 0px solid #ff0000 !important;
	color: #666 !important;
}

div.wpcf7-spam-blocked {
	border: 0px solid #ffa500 !important;
	color: #666 !important;
}

div.wpcf7-validation-errors {
	border: 0px solid #398f14 !important;
	color: #666 !important;
}

.wpcf7 {
	position: relative;
	z-index: 1;
}
