/** ------------------------------------------------------ **/
/** -------------------2 column layout -------------------- **/
body {
	color: #000000;
	font-family: 'futura-pt', sans-serif, Verdana, Helvetica;
	font-size: 0.8em;
	padding-inline:15px;
	max-width: 1910px;
    margin: 0 auto;
}

.container-fluid {
	margin-left:auto;
	margin-right:auto;
	max-width:1910px;
}

input[type=number]::-webkit-inner-spin-button, 
input[type=number]::-webkit-outer-spin-button { 
 	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;  
}
input[type=number]{
	-moz-appearance:textfield;
}

#skip-navigation{
	height:0px;	
	overflow: hidden; 
}

#wrapper-topbar, #wrapper-header {	
	max-width:1780px;
}
#wrapper-topbar-container {
	background-color:#FAFAFA;
}
#wrapper-header{
	background-color:#ffffff;
}
#wrapper-navigation {
	/* position:relative; */
	z-index:100;
}

.wrapper-inner{
	margin: 0 auto;
	position:relative;
	text-align: left;
	max-width: 1880px;
    width: 100%;
}
.wrapper-inner-medium {
	margin: 0 auto;
	position:relative;
	text-align: left;
	max-width: 1600px;
    width: 100%;
}
.wrapper-inner-small {
	margin: 0 auto;
	position:relative;
	text-align: left;
	max-width: 1000px;
    width: 100%;
}

#preview, #preview-admin{
	position:fixed;
	top:0px;
	left:0px;
	width:100%;
	z-index:2001;
}	
#preview p, #preview-admin p{
	background-color:#0000FF;
	color:#FFFFFF;
	margin:0px;
	padding:8px;
	font-size:14px;
	font-weight:bold;
}
#preview-admin p{
	background-color:#333333;
}

#wrapper-bespoke-quote {
	background-color:#0077c0;
	padding-bottom: 3rem !important;
    padding-top: 3rem !important;
}

.col-br {
	border-right: 2px solid #4b4b4b;
}

#wrapper-footer{
	background-color: #353535;
}	
#foot {
	max-width: 1780px;
}

/** ------------------------------------------------------ **/
/** ------------------- top bar ------------------------- **/

#topbar {
	list-style: none;
}
#topbar li {
	color: #54565b;
	font-size: 1.3em;
    font-weight: 500;
}
#topbar li span {
	color:#0077c0;
}
#topbar li a, #topbar li a:visited {
	color:#54565b;
	text-decoration: none;
}
#topbar li a:hover, #topbar li a:active {	
	color:#0077c0;
	text-decoration: none;
}

/** ------------------------------------------------------ **/
/** ------------------- header --------------------------- **/

#header_graphic{
	position:relative;
	z-index:500;
}
#header_graphic .largeScreen img{
	display:block;
}
#header_graphic .smallScreen img{
	display:none;
}

#header-phone a, #header-phone a:visited {
	float:right;
	font-size:1.4em;
	font-weight:600;
}

/** ------------------------------------------------------ **/
/** -------------------navigation ------------------------ **/

#navigation ul {
	display:inline-flex;
	list-style: none;
	margin: 0px;
	padding: 0px;
}

#navigation ul li {
	font-size:1em;
	padding: 0px;
	margin: 0px; 
}

#navigation ul li a, #navigation ul li a:visited {
	color: #3e3e3e;
	display: block;
	float: left;
	font-size: 1.3em;
	font-weight:500;
	padding-left: 0px;
	padding-right: 0px;
	padding-top:9px;
	text-decoration: none;
}
#navigation ul li a:hover, #navigation ul li a:active {	
	color: #0077c0;	
}

#navigation ul li .sub {
	background-color:#ececec;  
	/*border-bottom: 3px solid #4c4c4c;*/
	padding: 0px;
	margin: 0px;
	position: absolute;
	top:123px;
	left:-9999px;
	width:100%;
	z-index:500;
}
#navigation ul li .subnav{
	color:#FFFFFF;
	padding-top:20px;
	padding-bottom:20px;
}

#navigation ul li .subnav h2 {
	font-size: 1.6em;
}	
#navigation ul li .subnav .menu_header{
	display:none;
}
#navigation ul li:hover div.sub{
	left:0px;
}

#navigation ul li ul{
	display:block;
	float:left;
	margin:0px;
	margin-left:10px;
	margin-right:10px;
	padding:0px;
	width:275px;
}
	
#navigation ul li ul li {
	background-image:none;
	border-bottom: 1px solid #b0b0b0;
	display:block;
	float:none;
	height:auto;
	margin: 0; 
	margin-bottom:5px;
	padding: 0;
}	
#navigation ul li ul li a, #navigation ul li ul li a:visited{
	border:0px;
	color:#000000;
	display:block;
	float:none;
	font-size: 1.2em;
    font-weight: 400;
	margin-top:0px;
	padding-bottom:5px;
	padding-top:5px;
	padding-left:0px;
	padding-right:0px;
	text-transform:none;
}

#navigation ul li ul li a:hover, #navigation ul li ul li a:active {	
	color: #5e5e5e;
}

.navColumn{
	float:left;
	width:885px;
}

.navColumn ul li img.alignRight{
	margin-bottom:0px;
	margin-right:20px;
	height:28px;
	width:28px;;
}

.navColumnEnd{
	float:left;
	width:20%;
}
#navigation ul li .navColumnEnd ul{
	width:96%;
}	
	
#dropdown-bg{
	background-color:#ececec;
	border-bottom: 3px solid #4c4c4c;
	padding-bottom: 10px;
	display:none;
	height:10px;
	position:absolute;
	top:123px;
	left:0px;
	width:100%;
	z-index: 60;
}	

#nav-icon {
	display: none;
}
#navigation ul li a.nav-1 {
	width:85px;
}
#navigation ul li a.nav-2 {
	width:165px;
}
#navigation ul li a.nav-3 {
	width:85px;
}
#navigation ul li a.nav-4 {
	width:100px;
}
#navigation ul li a.nav-5 {
	width:110px;
}
#navigation ul li a.nav-6 {
	width:100px;
}
#navigation ul li a.nav-9 {
	width:95px;
}

	
/** ------------------------------------------------------ **/
/** ------------------------ menu ------------------------ **/
	
#leftc ul {
	list-style: none;
	margin: 0px;
	padding: 0px;	
}
#leftc ul li {
	margin: 0; 
	padding: 0; 
}

#leftc ul li a, #leftc ul li a:visited {
	border-bottom: 1px solid #ececec;
	color:#000000;
	display: block;
	font-size:0.8em;
	margin:0px;
	padding-bottom: 10px;
	padding-left: 0px;
	padding-right: 0px;
	padding-top: 10px;
	text-decoration: none;
}

#leftc ul li a:hover {
	color:#0077c0;
}


/** ------------------------------------------------------ **/
/** ------------------------ menu subsection ------------- **/

#submenu ul{
	list-style: none;
	margin: 0px;
	padding: 0px;
}
#submenu ul li{
	margin: 0; 
	padding: 0; 
}

#submenu ul li a, #submenu ul li a:visited{
	border-bottom: 1px solid #666666;
	display: block;
	font-size: 0.9em;
	font-weight: bold;
	padding-bottom: 5px;
	padding-left: 34px;
	padding-right: 0px;
	padding-top: 5px;
	text-decoration: none;	
	/*width avoids extra whitespace in ie5-6*/
	width: 194px;
}
* html #submenu ul li a,  #submenu ul li a:visited {  /* This is the Tan hack */
	width: 228px; 
	w\idth: 194px; 
}

/** ------------------------------------------------------ **/
/** --------------- bespoke quote form ------------------- **/

#bespoke-quote-form h2, #bespoke-quote-form p, #bespoke-quote-form a, #bespoke-quote-form a:visited, #bespoke-quote-form a:hover, #fabrications-form h2, #fabrications-form p {
	color:#ffffff;
}
#form-container {
	background-color: #0077c0;
}
.form-group {
	margin-bottom: 30px;
	position:relative;  
}
.form-label {
	font-size: 1.4em;
	font-weight: 500;
	position: absolute;
	left: 15px;
	top: 5px;
	color: #ffffff;
	z-index: 10;
	transition: transform 150ms ease-out, font-size 150ms ease-out;
}
.focused .form-label {
	transform: translateY(-150%);
	font-size: .95em;
}
.form-label.has_error{
	color: var(--red);
}
.form-control, .custom-select  {
	background-color: #0077c0;
	border-radius: 0px;
	position: relative;
	padding: 15px 15px 8px 15px;
	width: 100%;
	outline: 0;
	border: 0;
	box-shadow: 0 1px 0 0 #ffffff;
	transition: box-shadow 150ms ease-out;
}
.form-control:focus, .custom-select:focus  {
	background-color: #0077c0;
	box-shadow: 0 2px 0 0 #ffffff;
	color: #ffffff;
}

.form-control.filled  {
	background-color:#0077c0 !important;
	box-shadow: 0 2px 0 0 #ffffff;
	color: #ffffff !important;
}

.form-control.has_error  {
	background-color:#0077c0 !important;
	box-shadow: 0 2px 0 0 #db0032;
	color: #ffffff !important;
}

#submit-btn {
	background-color: #ffffff;
	border-radius: 0;
	color: #0077c0;
	font-size: 1.6em;
	font-weight: 600;
	transition: background-color 0.8s cubic-bezier(.19,1,.22,1), color 0.8s cubic-bezier(.19,1,.22,1);
}

#submit-btn:hover {
	background-color: #0077c0;
	color: #ffffff;
}

.error {
	color: #db0032;
	margin-top: 5px;
}

/** ------------------------------------------------------ **/
/** ----------------- iconcontent ----------------------- **/

#iconcontent h2 {
	color:#0077c0;
	font-size:3.5em;
	font-weight:400;
	text-align:center;
}
#iconcontent img {
	display: block;
    margin: 0 auto;
}
#iconcontent p {
    line-height: 1.5em;
	margin:0px;
}
.iconcontent-title {
	color:#0077c0;
	font-size: 2.2em;
    font-weight: 500;
	text-align:center;
}
.iconcontent-text {
	font-size: 1.8em;
    font-weight: 500;
	text-align:center;
	margin-bottom: 0px;
}

/** ------------------------------------------------------ **/
/** ------------------- footer --------------------------- **/

#foot ul{
	list-style:none;
	margin:0px;
	padding:0px;
}
#foot ul li{
	font-size:1em;
	padding-bottom:0px;
}
#foot ul li a, #foot ul li a:visited{
	color:#ffffff;
	font-size:1.3em;
	font-weight:400;
	line-height: 2.1em;
	text-decoration:none;
}

#footCatalogue h2, #footPartnership h2  {
	color: #ffffff;
	font-size:1.3em;
    font-weight: 400;
}
#footPartnership h2 {
    margin-bottom: 0px;
    padding-bottom: 1rem;
}

	
/** ------------------------------------------------------ **/
/** ------------------- HTML elements -------------------- **/

caption {
	font-weight: normal;
	text-align: left;	
}
th {
	font-weight: bold;
	text-align: left;	
}

/** ------------------------------------------------------ **/
/** ------------------- form ------------------------- **/

form {
  margin: 0px;
  padding: 0px;
  }
fieldset {
  border: 0px;
  margin:0px;
  padding: 0px;
  padding-top: 10px;
  width: auto;
  }
legend {
  font-weight: bold;
  padding-bottom: 10px;
}
input {
  float: left;
  margin-right: 10px
  }
select {
  float: left;
  margin-right: 10px
  }
textarea{
  margin-bottom:5px;
}	 
input.buttons {
  float: none;
}
form fieldset div {
  padding-bottom: 0px;
  clear: both;
  overflow:auto;
  }
form fieldset p {
  padding-bottom: 10px;
  margin: 0px;
  clear: both;
  }

.tradeSelect {
	clear: none;
	float: left;
	padding-bottom: 10px;
}  
.nofloat{
	float:none;
	margin-right:0px;
}	
/* hide anti spam box */
.sec-form-field {
	display: none;
}

.error {
    color: #FF0000;
}

.contactInput{
	border:1px solid #c2c2c2;
	color:#4c4c4c;
	font-family: 'futura-pt', sans-serif, Verdana, Helvetica;
	margin:0px;
	margin-bottom:11px;
	padding:0px;
	padding-bottom:7px;
	padding-top:8px;
	padding-left:11px;
	padding-right:11px;
	margin-right:10px;
}
.contactInputLarge{
	width:326px;
}
* html .contactInputLarge{
	width:350px;
	w\idth:326px;
}

.contactInputSmall{
	width:76px;
}
* html .contactInputSmall{
	width:100px;
	w\idth:76px;
}

select{
	border:1px solid #4c4c4c;
	color:#4c4c4c;
	font-family: 'futura-pt', sans-serif, Verdana, Helvetica;
	margin:0px;
	margin-bottom:11px;
	padding:0px;
	padding-bottom:7px;
	padding-top:8px;
	padding-left:11px;
	padding-right:11px;
	width:350px;
}

form fieldset div.tradefields {
	display: none;
}

input[type="text"]:read-only, input[type="tel"]:read-only, input[type="email"]:read-only, input[type="password"]:read-only, textarea:read-only  {
	background-color: #ffffff;
	border: 1px solid #bcbcbc;
	color: #bcbcbc;
	cursor: not-allowed;
}

/** ------------------------------------------------------ **/
/** ------------------- div table replacements ----------- **/

/*create a row*/
div.TableReplaceRow {
	clear: both;
	padding-top:0px;
  }
/*label cell*/
div.TableReplaceRow div.TableReplaceLeft {
	float: left;
	text-align: left;
	width: 200px;
	margin: 0px;
  }
/*data cell*/
div.TableReplaceRow div.TableReplaceRight {
	float: right;
	margin: 0px;
	margin-left: 27px;
	width: 500px;
  } 

div.TableReplaceRow div.TableReplaceLeftB {
	float: left;
	text-align: left;
	width: 580px;
	margin: 0px;
    width: 380px;
  }
/*data cell*/
div.TableReplaceRow div.TableReplaceRightB {
	float: right;
	margin: 0px;
	margin-left: 20px;
	width: 480px;
  } 
div.TableReplaceRow div.TableReplaceRightB h1 {
	font-size:2.3em;
	font-weight:500;
}

div.TableReplaceRow div.TableReplaceRightB .blue-hr{
	background-color:#0078c1;
	height:7px;
	margin-top:10px;
	margin-bottom:10px;
}

div.TableReplaceRow div.TableReplaceRightB #product-options label {
	color:#9c9c9c;
	font-size:1.3em;
	margin-right:0px;
	width:100%;
}
div.TableReplaceRow div.TableReplaceRightB #product-options select {
	max-width: 480px;
	width:100%;
}

div.TableReplaceRowClear {
	clear: both;
  }
  
.clearboth {
	clear:both;
}

.cookiesTable{
	margin-bottom:10px;
}
.cookiesTable td{
	padding:10px;
}

/** ------------------------------------------------------ **/
/** ------------------- bespoke -------------------------- **/

.border-col {
	padding-left: 8rem;
	padding-right:5rem;
	padding-block:1rem;
}

.border-col::after {
	content: "";
    width: 8px;
    height: 100%;
    background-color: #0077c0;
    position: absolute;
    right: 0;
    top: 0;
    border-radius: 5px;
}
.border-col + div {
	padding-right: 8rem;
	padding-left:5rem;
	padding-block:1rem;
}

.border-col h2 {
	font-size: 3.2em;
    font-weight: 300;
    line-height: 1.4em;
}

.grey-border {
	border-top:10px solid #e3e3e3;
}

#home-box{
	margin-left:18px;
}	

.menu-sub{
	color:#03729d;
	font-size:10px;
}

#selectboxes select{
	width:120px;
}

.topimage{
	display:block;
}

.featuretitle {
	background-color: #292929;
}

.featuretitle a, .featuretitle a:visited, .featuretitle h3 {
	color:#ffffff;
	font-size: 1.4em;
    font-weight: 500;
	text-align:center;
	text-decoration:none;
	margin-bottom:0px;
}

.featureimage img {
	height:auto;
	width:100%;
}

.last{
	margin-right:0px !important;
}

.breadcrumbs a, .breadcrumbs a:visited {
	color:#4c4c4c;
	text-decoration:none;
}
.breadcrumbs a:hover {
	text-decoration:underline;
}


/****** SWIPER *******/
.swiper-container {
    width: 100%;
    max-width: 940px;
    height: 500px;
    margin: 0 auto;
}

.swiper {
	background-color: #0077C0;
	margin-left: -15px;
	margin-right: -15px;
}

.swiper-slide picture, .page-banner img {
	z-index:-2;
}

.text-wrapper, .banner-text-wrapper {
	background-color: #0077C0;
	color: #fff;
	position: absolute;
	left: 0;
	top: 0;
	container-type: size;
	display: flex;
	align-items: left;
	flex-direction: column;
	justify-content: center;
	height: 100%;
	min-width: 35%;
	padding-block: 5cqi;
	padding-left: 6cqi;
	z-index: 1;
}
.text-wrapper::after, .banner-text-wrapper::after {
	background: inherit;
    bottom: 0;
    content: '';
    display: block;
    height: 100%;
    position: absolute;
    right: -17%;
    transform: skewX(-15.5deg);
    transform-origin: 100%;
    z-index: -1;
    width: 39%;
}

.slide-heading, .slide-subheading, .slide-text {
	color:#ffffff;
}
.slide-heading, .slide-subheading {
	font-weight: 300;
	text-transform:uppercase;
}
.slide-heading {
    font-size: 16cqi;
	line-height: 0.8em;
}
.slide-subheading {
	font-size: 8cqi;
}
.slide-text {
	font-size: 3.6cqi;
}

.text-wrapper .slide-link a {
	background-color: #fff;
	color: #0077C0;
	font-size: 4cqi;
    padding-inline: 10cqi;
}

#category-header-container {
	padding-top:20px;
}

/***** News *****/

.newsitem{
	border-bottom: 1px solid #dcdcdc;
	margin-bottom:20px;
	padding-bottom: 20px;
}
.newstext, .newsimage{
	float:left;
}
.newsimage{
	width:200px;
}
.newstext{
	padding-right:20px;
	width:660px;
}
.newstext p{
	margin-bottom:0px;
}
.newstext p a, .newstext p a:visited, .newstext h3 a, .newstext h3 a:visited{
	color:#ff6d18;
	text-decoration:none;
}

#divMapCanvas {
    height: 380px;
}

.underline{
	text-decoration:underline;
}	

.downloadImage img{
	margin-bottom:12px;
	width:100%;
}	
.downloadText h3, .downloadText p {
	font-size:1.3em;
}
.downloadText a, .downloadText a:visited{
	text-decoration:none;
}
.downloadLink{
	color: #0077c0;	
}

/***** Blog *****/

.blogItem {
	max-width: 368px;
}

.blogItem .blogPhoto {
	border: 1px solid #dcdcdc;
    display: flex;
	justify-content: center;
}
.blogItem .blogPhoto img{
	display: block;
    width: 100%;
}
.blogItem .blogText{
	padding: 5px 0px 5px 0px;
    bottom: 0px;
}
.blogItem .blogText p{
	font-size:1.2em;
	margin-bottom:12px;
}
.blogItem .blogText a, .blogItem .blogText a:visited{
	font-size:1.2em;
	float:right;
}
.blogItem .blogText .blogdate{
	margin-bottom:8px;
}	
.blogItem .blogText h3{
	background-color: #0077c0;
    color: #fff;
    line-height: 1.4em;
    padding: 10px 20px;
}

.blogItem .blogText h3 a, .blogItem .blogText h3 a:visited{
	color:#FFFFFF;
	float:none;
	text-decoration:none;
}	

#latestBlogs{
	margin-bottom:18px;
}		
.chosenOptionText {
	display: none;
}
a#reset {
	border-top: 7px solid #0078c1;
	float: left;
	margin-top: 10px;
	padding-top: 10px;
	width: 100%;
}
#options-reset {
	background-color: #4c4c4c;
	color: #ffffff;
	float: left;
	font-weight: 500;
    font-size: 1.2em;
	padding-top: 15px;
    padding-bottom: 15px;
	width: 180px;
	text-align: center;
	text-decoration: none;
}

.sitemap {
	clear: both;
	width: 100%;
}
.sitemap ul {
	margin-bottom: 10px;
	margin-top: 10px;
	padding-left: 40px;
}
.sitemap ul li ul {
	margin-bottom: 10px;
	margin-top: 10px;
	padding-left: 40px;
}
.sitemap ul li ul li {
	font-size: 1em;
}

#quote-wrapper {
	background-color: #0077c0;
	font-size: 1.8em;
	font-weight: 500;
	margin-bottom: 20px;
	padding-bottom: 15px;
	padding-left: 25px;
	padding-right: 25px;
	padding-top: 15px;
	text-align: center;
	width: 1130px;
}
* html #quote-wrapper {
	width: 1180px;
	w\idth: 1130px;
}

#quote-wrapper a, #quote-wrapper a:visited{
	color: #ffffff;
	text-decoration: none;
}
#quote-wrapper a:hover {
	color: #ffffff;
	text-decoration: underline;
}

#footRight h3 {
	color: #ffffff;
}
#footRight label {
	color: #ffffff;
	font-size: 1.2em;
	width: 100px;
}
#footRight input.contactInput {
	width: 250px;
}

#greySubmit, .greySubmit {
	background-color: #4c4c4c;
	border: 0px;
    color: #ffffff;
    font-size: 1.2em;
    padding-top: 10px;
    padding-bottom: 10px;
    width: 180px;
    text-align: center;
}

#productCount {
	color: #0078c1;
	font-weight: 500;
    font-size: 1.8em;
    font-style: normal;
    line-height: 1.0em;
}
span#capitals {
	text-transform: capitalize;
}
#readmore{
	float: right;
	margin-bottom: 15px;
}
#moreinfo{
	padding-top: 15px;
}

.infoCatContainer .infoLink, .infoCatContainer .infoLink:visited, .infoCatContainer h3 {
	background-color:#292929;
	color:#ffffff;
	display:block;
	font-size:1.4em;
	font-weight:500;
	text-align:center;
	text-decoration:none;
	margin:0px;
}
.infoCatContainer .infoLink:hover {
	color:#ffffff;
	text-decoration:none;
}

#cookiefirst-policy-page table th, #cookiefirst-policy-page table td {
	border:1px solid #000;
}

.formSuccess {
	text-align: center;
    font-weight: 700;
}
#emailError .redtext {
	background: #fff;
	border: 1px solid #000;
	display:block;
	font-size: 1.2em;
    font-weight: 600;
    margin-bottom: 30px;
    padding: 10px 20px;
}

.productImage {
	background-color:#0077c0;
}