
:root {
	--font-base: 'Open Sans', sans-serif;
	--font-heading: 'Roboto', serif;
	/* Cart Styling */
	--cartColourAccent: #ddd; /* Lines, close button etc. */
	--cartColourBackground: #f9f9f9; /* Backgorund of Cart Forms */
	--cartColourBackgroundAccent: #efefef; /* Backgorund of Cart Forms */
	--cartColourText: #555;
	--cartColourTextLight: #888;
	--cartColourLink: #555;
	/* Drawer Menu */
	--drawerColourAccent: rgba(0,0,0,0.1); /* Lines, close button etc. */
	--drawerColourBackground: #fff;
	--drawerColourText: #666;
	--drawerColourLink: var(--primary);
	--overlayColour: rgba(0,0,0,0.4); /* Background property for overlays */
}

/**
 * Base Styling
 */

body {
	font-family: var(--font-base);
}

h1, .h1,
h2, .h2,
h3, .h3,
h4, .h4,
h5, .h5,
h6, .h6 {
	font-family: var(--font-heading);
}

h2, .h2,
h3, .h3,
h4, .h4,
h5, .h5,
h6, .h6 {
	color: var(--primary);
}

/**h3, .h3,*/
h4, .h4,
h5, .h5,
h6, .h6 {
	text-transform: uppercase;
}

h1, .h1 {
	line-height: 1;
}

@media (max-width: 780px) {
	h1, .h1 {
		font-size:4.0rem!important;
	}
}

@media (max-width: 640px) {
	h1, .h1 {
		font-size:3.5rem!important;
	}
	.form {
		padding:1rem;
	}
	.form > div {
    margin-bottom: 0;
	}
}

@media (min-width: 641px) {
	.slideshow {
		display:flex;
	}
}

a {
	transition: all .2s;
}

.lead {
	color: var(--primary);
}

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

ul > li ul { list-style-type: circle; }
ol > li > ol { list-style-type: lower-alpha; }
ol > li > ol > li > ol	{ list-style-type: lower-roman; }

.fas.fa-phone::before {
	display: inline-block;
	transform: scaleX(-1);
}

.btn {
	text-transform: uppercase;
	transition: all .2s;
}

.btn:hover,
.btn:focus,
.subpage-link:hover,
.subpage-link:focus,
.product-card a:hover,
.product-card a:focus {
	transform: scale(1.1);
	outline: 1rem solid var(--primary);
	animation: pulse-outline 1.25s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}

.btn-secondary:hover,
.btn-secondary:focus {
	outline: 1rem solid var(--secondary);
}

.btn-danger:hover,
.btn-danger:focus {
	outline: 1rem solid var(--danger);
}

.btn-success:hover,
.btn-success:focus {
	outline: 1rem solid var(--success);
}

.btn-dark:hover,
.btn-dark:focus {
	outline: 1rem solid var(--dark);
}

.btn-light:hover,
.btn-light:focus {
	outline: 1rem solid var(--light);
}

@keyframes pulse-outline {
	0% {
		outline-width: 0;
	}
	80%, 100% {
		outline-color: transparent;
	}
}

@media (min-width: 1200px) {
	.columns {
		columns: 2;
		column-gap: 2rem;
	}

	.columns p,
	.columns div {
		break-inside: avoid-column;
	}
}


/**
* Section Background Image
*/

.bg-image {
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}


/**
* Section Parallax Effect
*/

.bg-parallax {
	background-attachment: fixed;
}

@supports (-webkit-touch-callout: none) {
	.bg-parallax {
		background-position: center;
		background-attachment: initial;
	}
}


/**
* Site Header
*/

header.main {
	background-color: #fff;
	z-index: 5;
}

header.main .global-nav {
	background-color: #eee;
	color: #888;
	font-size: 13px;
}

header.main .logo {
	display: inline-block;
	padding: 1rem 0;
}

header.main:not(.home) .logo {
	width: 120px;
}

/*@media (min-width: 1200px) and (min-height: 800px) {
	header.main {
		position: sticky;
		top: 0;
		z-index: 10;
	}
}*/

header.main:not(.home) {
	border-bottom: 1px solid #eee;
}

header.main {
	background-color: #fff;
	/* background-image: linear-gradient(0deg, rgba(220,221,222,1) 0%, rgba(220,221, 222,1) 100%); */
	color: #fff;
}

header.main.home {
	width: 100%;
}

header.main.home .contact-info {
	padding: 2.2rem 1rem;
	color: #fff;
	font-weight: bold;
}

header.main.home .contact-info a {
	color: inherit;
}

footer .contact-info i + span,
footer .contact-info i + a {
	padding-left: 5px;
}

#ContactFormUserEmail {
	display: none!important;
}

.mobile-header-btn {
	border-radius: 50px;
    background-color: #800000;
    color: #fff;
    border: none;
	font-size: 14px;
}

.fullwidth-bg {
	position: relative;
	padding-top: 5rem;
}

.fullwidth-bg:before {
	content: '';
    display: block;
    background-color: #eee;
    position: absolute;
    left: -100%;
    bottom: -21%;
    width: 300%;
    height: 120%;
    z-index: -1;
}

/**
* Main Dropdown Menu
*/

.ddmenu {
	position: relative;
	display: flex;
	align-items: center;
	z-index: 9;
	justify-content: flex-end;
}

.ddmenu nav {
	display: none;
}

.ddmenu nav ul {
	display: inline-flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 0;
	padding: 0;
}

.ddmenu nav li {
	position: relative;
	display: inline-flex;
	align-items: stretch;
}

.ddmenu-home nav li {
	display: flex;
	flex: 0 0 100%;
}

.ddmenu-home nav li div {
	width: 100%;
}

.ddmenu nav a {
	padding: .6rem 1rem;
	font-weight: bold;
	line-height: 1.2;
	text-decoration: none;
	text-transform: uppercase;
	display: flex;
	width: 100%;
	align-items: flex-end;
	transition: color .2s, background-color .2s;
	color: #58595b;
}

.ddmenu nav a:hover,
.ddmenu nav a:focus,
.ddmenu nav a.active {
	text-decoration: none;
}

.ddmenu nav > ul > li > div > a {
	border-bottom: 1px solid transparent;
}

.ddmenu nav > ul > li:hover > div > a,
.ddmenu nav > ul > li > div > a.active {
	border-bottom: 1px solid #800000;
	color: #800000;
}

.ddmenu-home nav a {
	position: relative;
	color: #58595b;
}

.ddmenu nav a:hover,
.ddmenu nav a:focus,
.ddmenu nav a.active {
	text-decoration: none;
	background-color: transparent;
	color: #f58220;
}

.ddmenu-home nav a::before {
	content: "";
	position: absolute;
	top: 50%;
	right: 200%;
	display: block;
	width: 10rem;
	height: 2px;
	background-color: #fff;
	transform: translateY(-50%);
	transition: all .2s;
}

.ddmenu-home nav a:hover::before,
.ddmenu-home nav a:focus::before,
.ddmenu-home nav a.active::before {
	right: 100%;
}

/* Level 2+ Default State */

.ddmenu nav li li {
	display: block;
	align-self: baseline;
}

.ddmenu nav li > ul {
	display: block;
	min-width: 250px;
	background-color: #eee;

	/* Styles for transition / hover */
	position: absolute;
	top: 50%;
	left: -10000px;
	pointer-events: none;
	opacity: 0;
	transition: opacity .2s, top .2s, left 0s ease .2s; /* transition OUT, left position to remove from viewport entirely MUST be done last after the transition */
}

/* Show / Visibility of Level 2 */

.ddmenu nav li:hover > ul {
	top: 100%;
	left: 0;
	transition: opacity .2s, top .2s, left 0s ease 0s;
	pointer-events: all;
	opacity: 1;
}

/* Level 2+ Link Styling */

.ddmenu nav li > ul a {
	color: #333;
	text-transform: initial;
	width: 100%;
}

.ddmenu nav li > ul a:hover,
.ddmenu nav li > ul a:focus {
	color: #333;
}

.ddmenu nav li > ul a:hover,
.ddmenu nav li > ul a:focus,
.ddmenu nav li > ul a.active {
	text-decoration: none;
	background-color: var(--primary);
	color: #fff;
}

/* Stop last dropdown from being half outside site edge */
.ddmenu nav > ul > li:last-child > ul {
	right: 0;
	left: initial;
}

/* Responsive Menu Toggle Buttons */
.ddmenu-toggler,
.ddmenu .close-btn {
	visibility: hidden;
	pointer-events: none;
	font-size: 1.2rem;
	display: none;
	position: relative;
}

.ddmenu .submenu_toggler {
	display: none;
	visibility: hidden;
}


.header-home .justify-content-center .contact-info {
	order: 1;
}

.header-home .justify-content-center .pb-4 {
	padding: 0 15px !important;
	order: 2;
}

.header-home .justify-content-center .ddmenu-home {
	order: 3;
}

@media(max-width: 991px) {
	header.main.home .contact-info i,

	header.main.home .contact-info a {
		color: #fff;
		border-color: #fff !important;
	}

	header.main.home .contact-info i.fa-phone {
		margin-right: 5px;
	}

	header.main .contact-info {
		padding: 5px 1rem 10px !important;
		display: flex;
		background: #303030;
		justify-content: space-between;
	}

	header.main .contact-info span {
		display: none;
	}

	header.main .contact-info .fa-phone + span {
		display: block;
	}
}
@media(min-width: 992px ) {
	.ddmenu nav {
		display: block;
	}

	.ddmenu [data-squidyToggle] {
		display: none;
	}

	.mobile-header-btn {
		display: none;
	}
	.main.innerpage {
		margin-top: 115px;
	}
	header.main.home {
		position: relative;
	}

	header.main {
		box-shadow: 0 0 1rem -.5rem rgba(0, 0, 0, .5);
	}

	.header-home {
		position: fixed;
		z-index: 99;

	}

	header.main .logo {
		padding: 0 0 1rem;
	}

	.header-home .justify-content-center {
		justify-content: space-between !important;
	}

	.header-home .justify-content-center .contact-info {
		order: 1;
		padding: 0 .99rem 0 !important;
		display: flex;
		justify-content: space-between;
	}

	header.main.home:after {
		content: '';
		display: block;
		/* background-image: linear-gradient(0deg, rgba(220,221,222,1) 0%, rgba(220,221, 222,1) 100%); */
		background-color: #303030;
		position: absolute;
		width: 100%;
		height: 45px;
		top: 0;
		left: 0;
		z-index: -1;
	}

	
	header.main.home .contact-info i,
	header.main.home .contact-info span {
		color: #fff;
	}

	header.main.home .contact-info i {
		border-color: #fff !important;
		font-size: 15px;
		width: 28px !important;
		height: 28px !important;
	}

	header.main.home .contact-info i, 
	footer.main .contact-info i {
		margin: .5rem .5rem 0 0 !important;
	}
	
	.header-home .justify-content-center .contact-info {
		padding: 0 .99rem 17px !important;
		display: flex;
		justify-content: space-between;
	}

	.header-home .justify-content-center .ddmenu-home {
		padding-left: 50px;
		padding-right: 0;
	}
	
	.header-home .justify-content-center nav {
		width: 100%;
		text-align: right;
	}

	.ddmenu-home nav li {
		display: inline-block;
		flex: none;
	}

	.ddmenu-home nav a::before {
		display: none;
	}
}


/**
* Carousel (Slideshow)
*/

.carousel {
	height: 600px;
}
.carousel-inner {
	position: relative;
	height: 100%;
}

.carousel-item,
.carousel-item picture,
.carousel-item img {
	height: 100%;
	object-fit: cover;
}

.carousel-inner::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	z-index: 1;
	background: linear-gradient(0deg, rgba(0,0,0,0.6964986678265056) 0%, rgba(0,0,0,0.2623249983587185) 100%);
}

.carousel-overlay {
	position: absolute;
	top: 35%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
	text-align: center;
	color: #fff;
	z-index: 2;
}

.carousel-overlay *:not(.btn) {
	color: inherit;
}

.carousel-overlay h1 {
	font-weight: 800;
	margin: 0;
	line-height: 1.1;
}

.carousel-overlay .lead {
	font-size: 24px;
	line-height: 1.1;
}

@media (min-width: 992px) {
	.carousel {
		height: 669px;
		margin-top: 112px;
	}
	.carousel-overlay h1 {
		font-size: 66px;
	}
	.carousel-overlay .lead {
		font-size: 34px;
	}

	.carousel-overlay {
		top: 35%;
	}
}

@media (min-width: 1200px) {
	.carousel {
		margin-top: 121px;
	}
}

@media (min-width: 1440px) {
	.carousel {
		margin-top: 140px;
	}
	.carousel-overlay h1 {
		font-size: 100px;
	}
	.carousel-overlay .lead {
		font-size: 54px;
	}
	

	.carousel-overlay {
		top: 30%;
	}
}


@media (min-width: 2560px) {	
	.carousel {
		height: 892px;
	}
	.carousel-overlay {
		top: 35%;
	}

}

.carousel-inner picture img {
	width: 100%;
}


/**
* Main Section
*/

.welcome-images {
	position: relative;
	padding-bottom: 4rem;
}

.welcome-images {
	margin-bottom: 2rem;
}

.welcome-images .overlay-image img {
	position: absolute;
	top: 100%;
	transform: translate(-80%, -100%);
}

.welcome-images + div *:not(h1, h2, h3, h4, h5, h6) {
    color: #fff;
}

@media (min-width: 1200px) {
	.welcome-images .overlay-image img {
		transform: translate(-92%, -100%);
	}
}

@media (min-width: 1440px) {
	.welcome-images {
		margin-bottom: 0;
	}
	.welcome-images .overlay-image img {
		transform: translate(-80%, -100%);
	}
}

section.main > .container:not(:empty) {
	padding-top: 5rem;
	padding-bottom: 5rem;
}

section.main > .container:last-child:not(:empty) {
	padding-bottom: 5rem;
}

section.main > .container.subpage-container {
	padding-top: 0;
}

@media (min-width: 1200px) {
	.container.narrow-container {
		max-width: 900px;
	}
	section.main .container.legal-container {
		max-width: 800px;
		background-color: #f8f8f8;
		padding: 4rem 3rem !important;
		margin-bottom: 6rem;
	}
}


/**
* Icons Banner
*/

section.icons {
	padding: 3rem 0;
	background-color: #800000;
}

.icon-link {
	display: flex;
	align-items: center;
	height: 100%;
	width: 100%;
	color: #000;
}

.icon-link:hover,
.icon-link:focus {
	color: var(--primary);
	text-decoration: none;
}

/**
.icon-link .icon-img {
	border: 1px solid var(--primary);
	border-radius: 50rem;
	flex: 0 0 90px;
}

.icon-link:hover .icon-img,
.icon-link:focus .icon-img {
	background-color: var(--primary);
	transition: all .2s;
}

.icon-link:hover .icon-img {
	transition: all .2s;
}

.icon-link:hover .icon-img img,
.icon-link:focus .icon-img img {
	filter: brightness(100);
}

.icon-link:hover .icon-img,
.icon-link:focus .icon-img {
	transform: scale(1.1);
	outline: 1rem solid var(--primary);
	animation: pulse-outline 1.25s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}

.icon-link .icon-text {
	font-size: 19px;
	font-weight: 700;
	line-height: 1;
	padding-left: 1rem;
}
*/

.icon-link {
	display: flex;
	align-items: center;
	justify-content: center;
}

.icon-link .icon-img {
	border: 2px solid var(--primary);
	border-radius: 50%;
	width: 120px;  /* Increase size */
	height: 120px; /* Match width for a perfect circle */
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.2s ease;
}

.icon-link:hover .icon-img,
.icon-link:focus .icon-img {
	background-color: var(--primary);
	transform: scale(1.1);
	outline: 1rem solid var(--primary);
	animation: pulse-outline 1.25s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
}

.icon-link .icon-img img {
	max-width: 70%; /* Keeps the icon image centered and proportional */
	transition: filter 0.2s;
}

.icon-link:hover .icon-img img,
.icon-link:focus .icon-img img {
	filter: brightness(100);
}

/**
* Services Section
*/

section.services {
	border-top: 11px solid var(--primary);
	border-bottom: 11px solid var(--primary);
	padding: 5rem 0;
	color: #fff;
}

section.services h1 {
	text-align: center;
	color: #fff;
	margin-bottom: 4rem;
}


/**
* Projects Section
*/

section.featured {
	padding: 7rem 0;
}

section.featured h1 {
	text-align: center;
	margin-bottom: 4rem;
}


/**
* Quick Contact Section
*/

section.quick-contact .form-col {
	padding: 7rem 1rem;
	background-color: rgba(255,255,255,0.76);
}

section.quick-contact .form-control {
	box-shadow: .3rem .3rem .5rem rgba(0,0,0,0.2);
}

@media (min-width: 1440px) {
	section.quick-contact .container {
		max-width: 1800px;
	}
	section.quick-contact .form-col {
		padding: 7rem 4rem;
	}
}


/* IMAGE STYLING */

.outerpair1 { background: url("../../images/upperrightfade.png") no-repeat right top; }
.outerpair2 { background: url("../../images/lowerleftfade.png") no-repeat left bottom; padding-top: 8px; padding-left: 8px; }
.shadowbox { background: url("../../images/shadow.png") bottom right; }
.innerbox { position: relative; left: -8px; top: -8px; }
.shadowbox img { border: 1px solid #333; vertical-align: bottom; }

.pageimagecenter { text-align: center; margin: 0 auto; padding: 0; max-width: 100%; }
.pageimageright { float: right; margin: 5px 0 5px 5px; padding: 0; max-width: 100%; }
.pageimageleft { float: left; margin: 5px 5px 5px 0; padding: 0; max-width: 100%; }
.pageimagenone img { margin: 3px; padding: 0; }


/* SOCIAL SHARING BUTTONS */

#social {
	height: auto;
	padding: 20px 0;
	overflow: hidden;
}


/**
 * Page Gallery
 */

.pagegalleryheading {
	display:none;
	font-size: 1.5rem;
	margin-bottom: 1rem;
}

.pagegalleryinner {
	display: flex;
	flex-wrap: wrap;
}

.pagegalleryimage {
	flex: 0 0 50%;
}

@media (min-width: 830px) {
	.pagegalleryimage {
		flex: 0 0 25%;
	}
}

.pagegalleryimage a {
	display: block;
	position: relative;
	padding-bottom: 90%;
	height: 0;
	overflow: hidden;
}

.pagegalleryimage img {
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: brightness(90%);
	transition: filter 1s, transform .5s;
}

.pagegalleryimage a:hover img,
.pagegalleryimage a:focus img {
	filter: brightness(100%);
	transform: scale(1.3);
}


/**
 * Sitemap
 */

#sitemap a { text-decoration: none; }
.sitemapL2:before,
.sitemapL3:before,
.sitemapL4:before,
.sitemapL5:before,
.sitemapL6:before { content: "\00BB"; display: inline-block; margin: 0 3px 0 0; }
.sitemapL1 { margin: 0 0 5px 0;  }
.sitemapL1 a { font-size: 16px; text-transform: uppercase; font-weight: bold; }
.sitemapL2 { margin: 10px 0 3px 10px; }
.sitemapL2 a { color: #333333; text-transform: uppercase; }
.sitemapL3 { margin: 0 0 3px 20px; }
.sitemapL4 { margin: 0 0 3px 30px; }
.sitemapL5 { margin: 0 0 3px 50px; }
.sitemapL6 { margin: 0 0 3px 60px; }



/**
* Subpages
*/

a.subpage-link {
	position: relative;
	display: flex;
	flex-direction: column;
	margin-bottom: 2rem;
	width: 100%;
	background-color: #fff;
	z-index: 1;
}

a.subpage-link:hover {
	text-decoration: none;
}

a.subpage-link:focus {
	outline: 3px solid lightblue;
	z-index: 3;
}

.subpage-image img {
	width: 100%;
	max-height: 100%;
	object-fit: cover;
	--aspect-ratio: 7 / 5;
	aspect-ratio: 7 / 5;
}

a.subpage-link .subpage-text {
	display: flex;
	flex-wrap: wrap;
	padding: 2rem;
	flex: 1;
}

a.subpage-link .subpage-text h4 {
	font-weight: bold;
	font-size: 22px;
}

a.subpage-link .subpage-text p {
	margin-bottom: 1.5rem;
	color: #626262;
	font-size: 15px;
}

a.subpage-link .subpage-text .btn {
	margin-top: auto;
	font-size: .9rem;
}


/**
* Product List Cards
*/

.product-list {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	margin: 0 -1rem;
}

.product-list .no-results {
	padding: 1rem;
}

.product-card {
	position: relative;
	display: flex;
	align-items: stretch;
	margin-bottom: 2rem;
}

.product-card-inner {
	position: relative;
	width: 100%;
}

.product-card-img a {
	display: block;
}

.product-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	--aspect-ratio: 7 / 5;
	aspect-ratio: 7 / 5;
}

.product-card a {
	text-decoration: none;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.product-card-title {
	display: flex;
	align-items: center;
	padding: 1rem;
	background-color: var(--primary);
	transition: all .2s;
	flex: 1;
}

.product-card a:hover .product-card-title,
.product-card a:focus .product-card-title {
	background-color: var(--secondary);
}

.product-card h5 {
	margin-bottom: 0;
	color: #fff;
}


/**
* Product Page Layout
*/

.product .hero {
	position: relative;
}

.product .hero::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, rgba(255,255,255,0.5536415249693627) 0%, rgba(33,61,131,0.6572829815519958) 29%, rgba(26,87,164,0.4023810207676821) 57%, rgba(255,255,255,0.7525210767900911) 100%);
	pointer-events: none;
	z-index: 0;
}

.product .hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	--aspect-ratio: 1 / 1.5;
	aspect-ratio: 1 / 1.5;
}

@media (max-width: 640px) {
	.product .hero::after {
		background:none;
	}
}

@media (min-width: 768px) {
	.product .hero img {
		--aspect-ratio: 3 / 2;
		aspect-ratio: 3 / 2;
	}
}

@media (min-width: 992px) {
	.product .hero img {
		--aspect-ratio: 5 / 2;
		aspect-ratio: 5 / 2;
	}
}

@media (min-width: 1440px) {
	.product .hero img {
		--aspect-ratio: 7 / 2;
		aspect-ratio: 7 / 2;
	}
}

.product .product-title {
	position: absolute;
	bottom: 5rem;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	color: #fff;
	z-index: 1;
}

.product .product-title .inner {
	max-width: 700px;
}

.product .product-title h1 {
	margin-bottom: 0;
	color: inherit;
	padding-bottom: 1rem;
	border-bottom: 3px solid #fff;
}

.product .product-title .location {
	font-size: 1.5rem;
	font-weight: 300;
	color: rgba(255,255,255,0.6);
}

.product .product-title .builder {
	padding-top: 1.5rem;
	color: rgba(255,255,255,0.7);
	text-transform: uppercase;
	letter-spacing: .4rem;
}

.product {
	overflow: hidden;
}

.product-summary-outer {
	max-width: 700px;
	padding: 4rem 0;
	font-size: 1.25rem;
	font-weight: 300;
}

.product-specs {
	background-color: #f8f8f8;
	padding: 2rem 0;
}

@media (min-width: 768px) {
	.product-specs {
		padding: 2rem;
	}
}

.logos {
	margin-bottom: 5rem;
}

.product-logos {
	display: flex;
	align-items: center;
	margin: 0 -1.5rem;
}

.product-logos .product-logo {
	flex: 0 1 50%;
	padding: 0 1.5rem;
	filter: grayscale(1);
	opacity: .5;
	transition: all .2s;
}

@media (min-width: 768px) {
	.product-logos .product-logo {
		flex: 0 1 33.333%;
	}
}

.product-logos .product-logo:hover {
	filter: grayscale(0);
	opacity: 1;
}

.product-image-big {
	display: block;
	margin-bottom: 5rem;
}

@media (min-width: 992px) {
	.product-image-big {
		width: 43.333vw;
		padding: 5rem 0;
		color: inherit;
		height: 100%;
		margin: 0;
	}
	.product-image-big img {
		width: 43.333vw;
		max-width: none;
		height: 100%;
		object-fit: cover;
	}
}

.product-images {
	display: flex;
	align-items: stretch;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 5rem;
}

.product-images .product-image {
	flex: 0 0 50%;
}

.product-images .product-image img {
	--aspect-ratio: 7 / 5;
	aspect-ratio: 7 / 5;
}

@media (min-width: 1200px) {
	.product-images .product-image {
		flex: 0 0 33.3333%;
	}

	.product-images .product-image {
		background: linear-gradient(90deg, rgba(37,43,104,0.8953782196472339) 0%, rgba(37,33,104,0.42198886390493695) 100%);
	}

	.product-images .product-image img {
		transition: all .2s;
		opacity: 1;
	}

	.product-images .product-image:hover img,
	.product-images .product-image:focus img {
		opacity: .7;
	}
}


/**
 * Lower Contact Message
 */

#contact { clear: both; width: auto; margin: 20px auto; color: #000000; font-size: 14px; text-align: center; }
#contact a { color: #ffffff; text-decoration: none; }


/**
 * Social Icons
 */

.social-icon {
	padding: .3rem;
}


/**
 * Contact Page
 */

#contactform #contact_thanks { padding: 15px; margin: 0 auto; width: 100%; text-align: center; border: 1px solid var(--cartColourBackgroundAccent); background: var(--cartColourBackground); }

#contactpage {
	background-color: var(--cartColourBackground);
	margin-bottom: 4rem;
}

.maps {
	margin-top: 2rem;
	height: 300px;
}

.maps iframe {
	height: 100%;
}
iframe { width: 100%; border: none; }
#contact-us iframe { height:400px; padding-top: 40px; }


/**
* Site Forms
*/

.form .error {
	color: #721c24;
	background-color: #f8d7da;
	border-color: #f5c6cb;
}

.form {
	display: flex;
	flex-wrap: wrap;
	padding: 3rem;
	background-color: var(--cartColourBackground);
	max-width: 700px;
	margin: 0 auto;
}

.form p {
	width: 100%;
}

.form .form {
	padding: 0;
}

.form > div {
	flex: 0 0 100%;
	margin-bottom: 1rem;
}

/* Submit button has a submit text label, hide it */
.form > div:last-of-type label {
	display: none;
	visibility: hidden;
	pointer-events: none;
}

.form .form-control {
	margin-bottom: 2rem;
}


/**
 * footer.main
 */

footer.main {
	padding-top: 5rem;
	clear: both; /* Don't like it, but provides a little layout protection where floats are used larger than the document flow */
	background-color: #eee;
	color: #fff;
}

footer.main a {
	color: inherit;
}

footer.main h3 {
	position: relative;
	font-size: 22px;
	color: #fff;
	padding-bottom: 1rem;
	margin-bottom: 1.3rem;
}

footer.main h3::after {
	content: "";
	position: absolute;
	top: 100%;
	left: -1rem;
	display: block;
	width: calc(100% + 2rem);
	height: 1px;
	background-color: #fff;
}

footer.main .quick-menu ul {
	margin: 0;
	padding: 0;
}

footer.main .quick-menu li {
	list-style: none;
	margin: 0 0 1rem 0;
	padding: 0;
	line-height: .8;
}

footer.main .quick-menu a {
	font-size: 14px;
	font-weight: 500;
}

header.main.home .contact-info span,
footer.main .contact-info span {
	padding-top: .55rem;
}

header.main.home .contact-info i,
footer.main .contact-info i {
	display: inline-flex;
	width: 33px;
	height: 33px;
	align-items: center;
	justify-content: center;
	border: 1px solid #fff;
	border-radius: 50rem;
	margin: .3rem 0 0 0;
}

header.main.home .contact-info i::before,
footer.main .contact-info i::before {
	margin-left: .3rem;
}

footer.main .legal {
	text-align: center;
	color: #6a6a6f;
	font-size: 14px;
	padding: 1.7rem;
	margin-top: 2rem;
}

footer.main .legal .quick-menu a {
	color: #6a6a6f;
}

footer.main .legal .quick-menu li {
	padding-left: .8rem;
	display: inline-block;
}

footer.main .legal .quick-menu li:not(:last-child) {
	padding-right: 1rem;
}

footer.main .legal .quick-menu li:not(:last-child) {
	border-right: 1px solid #666;
}


/**
* Drawer Styling
* Menu, Fancy Cart, and other stuff
*/

.drawer-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--overlayColour);
	opacity: 0;
	z-index: 91;
	transition: opacity .3s ease;
	visibility: hidden;
}

.drawer-overlay.visible {
	opacity: 1;
	visibility: visible;
}

.drawer {
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	transform: translateX(-110%);
	width: 350px;
	max-width: 95%;
	height: 100%;
	background-color: var(--drawerColourBackground);
	color: var(--drawerColourText);
	box-shadow: 0 0 2rem -1rem rgba(0,0,0,1);
	z-index: 91;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: opacity .3s ease, transform .3s ease;
}

.drawer.visible {
	transform: translateX(0);
}

.drawer-header {
	border-bottom: 1px solid var(--drawerColourAccent);
	padding: .8rem .5rem;
	margin: 0;
	background-color: #800000;
}

.drawer-header .drawer-title {
	margin: 0;
	color: #fff;
	font-weight: 400;
	letter-spacing: 1px;
}

.drawer-header .drawer-close {
	color: var(--drawerColourText);
	font-size: 130%;
	padding: 0 .8rem;
	color: #fff;
}

.drawer-content {
	overflow: hidden;
	overflow-y: auto;
	flex: 1 1 auto;
	padding-bottom: 3rem;
}


/**
 * Drawer Menu
 */

.drawer nav ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.drawer nav div {
	display: flex;
}

.drawer nav a {
	display: flex;
	justify-content: space-between;
	flex: 1 1 auto;
	color: var(--drawerColourLink);
	border-bottom: 1px solid var(--drawerColourAccent);
	text-decoration: none;
	text-transform: uppercase;
	font-size: .9rem;
	letter-spacing: 1px;
}

.drawer nav a span {
	display: inline-block;
	padding: .8rem 1rem;
}

.drawer nav ul li .toggler {
	display: flex;
	align-items: center;
	padding: 0 1.2rem;
	font-size: 120%;
	border-left: 1px solid var(--drawerColourAccent);
	cursor: pointer;
}

.drawer nav ul li ul .toggler {
	border-left: transparent;
	background-color: transparent;
	font-size: 100%;
}

.drawer nav li ul li a {
	text-transform: initial;
	padding: .5rem 0 .5rem 1.6rem;
}

.drawer nav li ul li ul li a {
	padding-left: 2.5rem;
}

/* Submenu (Closed State) */
.drawer nav li ul {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transition: max-height 0.5s ease-out, opacity .2s ease-out;
}

/* Submenu (Open State) */
.drawer nav li ul.visible {
	max-height: 3000px;
	opacity: 1;
}

/**
 * Debug
 */

#debug { position: relative; padding: 10px 15px; text-align: left; background: #cfdaff; border-top: 12px solid #c4d2ff; border-bottom: 12px solid #c4d2ff; }
#debug h1 { border: none; color: #001b51; text-transform: none; text-decoration: none; }
#debug pre { color: #000d27; }
