/*
! tailwindcss v3.4.0 | MIT License | https://tailwindcss.com
*//*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: "Inter", sans-serif; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
  color: inherit;
  text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
[type='button'],
[type='reset'],
[type='submit'] {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

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

/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden] {
  display: none;
}

*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
}
:root {
	--font: 'Inter', sans-serif;
	--font-weight: 400;
	--wrapper: 1440px;
	--inner: 1280px;
	--inner-content: 1160px;
	--inner-padding: 20px;
	--text-default: 16px;
	--text-info-box: 0.75rem; /* 12px */
	--text-copyright: 0.75rem; /* 12px */
	--text-small: 0.875rem;
	--text-smallest: 0.75rem;
	--bold: 700;
	--light: var(--font-weight);
	--lightest: 300;
	--academy-blue: #0B3854;
	/* --academy-teal: #00A2A6; */
	--academy-teal: var(--selo-blue);
	--enigma-blue: #0E1F37;
	--enigma-blue-tint: #547C9D;
	--enigma-grey: #676C6E;
	--enigma-grey-tint-10: #F4F4F4;
	--enigma-grey-tint-20: #E2E2E2;
	--enigma-grey-tint-50: #B5B6B6;
	--enigma-grey-fade: linear-gradient(180deg, rgba(244,244,244,1) 90%, rgba(255,255,255,1) 100%);
	--enigma-tan: #9F754D;
	--enigma-white: #fff;
	--selo-blue: #0181C5;
	--modulo-green-dark: #1D322B;
	/* --modulo-green-primary: #344E44; */
	--selo-construction-black: #000;
	--selo-construction-grey: #6C6D6F;
	--modulo-green-accent: #72BF44;
	--modulo-green-pale: #F0F7E8;
	--modulo-green-fade: linear-gradient(180deg, rgba(240,247,232,1) 90%, rgba(255,255,255,1) 100%);
	--nbs: #4D1254;
	--menu-heading: 1rem;
	--menu-heading-weight: 700;
	--menu-heading-colour: var(--modulo-green-primary);
	--menu-heading-colour-hover: var(--selo-blue);
	--menu-sub-heading: 1.3125rem;
	--menu-sub-heading-weight: 700;
	--menu-sub-heading-colour: var(--modulo-green-primary);
	--menu-sub-heading-colour-hover: var(--selo-blue);
	--menu-sub-text: 1rem;
	--menu-sub-text-weight: 400;
	--menu-sub-text-colour: var(--enigma-grey);
	--button-padding: 10px 25px;
	--button-colour: #fff;
	/* --button-background: var(--modulo-green-dark);
	--button-background-hover: var(--modulo-green-dark); */
	--button-background: var(--selo-blue);
	--button-background-hover: var(--selo-blue);
	--button-radius: 5px;
	--h1: 1.875rem;
	--h2: 1.3125rem;
	--h3: 1.25rem;
	/* --hero-slider: clamp(2.5rem, 2.5rem + 2.7778vw, 5rem); */
	--hero-slider: clamp(2.1875rem, 2.1875rem + 3.125vw, 5rem);
	--text-26: 1.625rem;
	--block-heading: 1.625rem;
	--intro-text: 1.25rem;
	--border-radius: 6px;
	--carousel-heading: 1.625rem;
	--padding-20: clamp(1rem, 0.929rem + 0.357vw, 1.25rem);
	--padding-30: clamp(1rem, 0.75rem + 1.26vw, 1.88rem);
	--padding-40: clamp(1rem, 0.57rem + 2.14vw, 2.5rem);
	--padding-45: clamp(1rem, 0.486rem + 2.57vw, 2.8rem);
	--padding-80: clamp(1rem, -0.143rem + 5.71vw, 5rem);
	--text-spacing: 2px;
}
@media screen and (max-width: 850px) {
		:root {
			--menu-sub-heading: 1.125rem;
			--menu-sub-text: var(--text-small);
		}
	}
.screen-reader-text,
.gfield--type-honeypot,
.producttab-form .gfield--type-honeypot,
.gfield_required_text,
.gform_submission_error.hide_summary,
.navigation.posts-navigation {
	border: 0 !important;
	clip: rect(1px, 1px, 1px, 1px) !important;
	-webkit-clip-path: inset(50%) !important;
	        clip-path: inset(50%) !important;
	height: 1px !important;
	margin: -1px !important;
	overflow: hidden !important;
	padding: 0 !important;
	position: absolute !important;
	width: 1px !important;
	word-wrap: normal !important;
}
.text-tan,
.button-border-blue.text-tan {
	color: var(--selo-construction-black);
}
.text-blue,
.button-tan.text-blue,
.button-border-blue.text-blue,
.button-border-blue.text-blue {
	color: var(--selo-construction-black);
}
.text-blue-accent {
	color: var(--selo-blue);
}
.button-blue {
	color: #fff !important;
	background: var(--selo-blue) !important;
	border-color: var(--selo-blue) !important;
}
.button-blue:hover,
	.button-blue:focus {
		color: #fff !important;
		background: var(--selo-blue) !important;
		border-color: var(--selo-blue) !important;
	}
.button-black {
	color: #fff !important;
	background: var(--selo-construction-black) !important;
}
.button-black:hover,
	.button-black:focus {
		color: #fff !important;
		background: var(--selo-blue) !important;
		border-color: var(--selo-blue) !important;
	}
.full-width {
	width: 100vw !important;
	position: relative !important;
	left: 50% !important;
	right: 50% !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	max-width: unset !important;
	overflow: hidden;
}
.bg-grey {
	background: var(--enigma-grey-tint-10) !important;
}
.text-wide {
	letter-spacing: var(--text-spacing);
	text-transform: uppercase;
	font-size: var(--text-small);
	font-weight: var(--bold);
}
html,
body {
	font-family: var(--font);
}
body {
	font-family: var(--font);
	font-size: var(--text-default);
	font-weight: var(--font-weight);
	color: #000;
}
bold,
bolder,
strong {
	font-weight: var(--bold);
}
h1 {
	font-size: var(--h1);
	color: #000;
}
h1,
	h1 span {
		font-weight: var(--lightest);
	}
h1 strong {
		font-weight: var(--bold);
	}
.intro-text {
	font-size: var(--intro-text);
	font-weight: var(--lightest);
	color: #000;
	padding: 10px 0 0;
}
main .woocommerce .products .product a p {
	color: #000;
}
.product-heading h1 {
	font-weight: var(--bold);
}
.product-heading__text p {
	font-size: 1em;
	font-weight: var(--lightest);
}
.product-heading__text p:first-of-type {
	font-size: var(--intro-text);
	font-weight: var(--lightest);
	margin: 10px 0 15px;
}
.light-text {
	font-weight: var(--lightest);
}
.video-library__item--term {
	font-weight: var(--bold);
	font-size: var(--text-small);
	color: var(--selo-construction-black);
	margin-top: 25px;
	display: block;
}
html,
body {
	background-color: #fff;
	width: 100vw;
	overflow-x: hidden;
	font-optical-sizing: auto;
	font-weight: 300;
	font-style: normal;
	/* font-variation-settings: "slnt" 0; */
}
#header {
	--header-top-text: 0.8125em;
	/* border-bottom: 1px solid var(--enigma-grey-tint-20); */
	background-color: #000;
	position: relative;
	z-index: 10;
}
@media screen and (max-width: 640px) {
	#header {
		/* height: 80px; */
	}
	.sub-header.sub-header-open {
		margin-top: 79px;
	}
	#header .header__logo img {
		max-height: 49px;
		width: auto;
	}

	body.single-product #header {
		height: unset;
	}
}
body.single-product #header {
	border-bottom: 0;
}
.header__menu {
	width: 100%;
	margin: 0 auto;
	padding: 25px var(--inner-padding) 25px var(--inner-padding);
	position: relative;
}
.header__menu--inner {
		display: flex;
		flex-wrap: wrap;
		max-width: var(--inner);
		margin: 0 auto;
		width: 100%;
		justify-content: space-between;
	}
.logo {

}
body.home.sub-header-is-open .logo,
body.home.sub-header-is-open .email-icon-header,
body.home.sub-header-is-open .telephone-icon-header,
body.home.sub-header-is-open .installations-icon-header {
	display: none;
}
body.home.sub-header-is-open .logo-home-blue,
body.home.sub-header-is-open .email-home-blue,
body.home.sub-header-is-open .telephone-home-blue,
body.home.sub-header-is-open .installations-home-blue {
	display: inline-block !important;
}
.heading-nav__top {
	font-size: var(--header-top-text);
}
.header__email a,
.header__tel a,
.header__installation a {
	font-weight: var(--bold);
	color: #fff;
}
.header__email a {
	display: block;
	margin: auto 28px auto 0;
}
.header__email img {
	display: block;
}
.header__tel a {
	display: block;
	margin: auto 0 auto 0;
}
.header__tel a *,
	.header__installation a * {
		display: inline-block;
	}
.header__installation a {
	display: block;
}
.header__installation a img {
		margin-right: 5px;
	}
#heading-nav {
	position: relative;
	z-index: 1000;
	width: calc(100% - 300px);
}
#primary-menu {
		margin-right: -15px;
		margin-top: 12px;
	}
#primary-menu li a,
	#primary-menu li button {
		color: #fff;
		font-size: var(--menu-heading);
		font-weight: var(--menu-heading-weight);
		display: inline-block;
		padding: 10px 15px;
	}
#primary-menu li a:hover,
	#primary-menu li a:focus,
	#primary-menu li button:hover,
	#primary-menu li button:focus {
		color: var(--menu-heading-colour-hover);
	}
#primary-menu li {
		margin: 0 10px;
	}
#primary-menu li:last-of-type {
		margin-right: 0;
	}
/* Home Page. */
/* body.home:not(.sub-header-is-open) #header {
    background: transparent;
	border-bottom: 0;
} */
/* body.home #header {
	position: absolute;
    width: 100%;
	z-index: 100;
} */
body.home #content {
	position: relative;
	top: -75px;
	margin-bottom: -75px;
	padding-bottom: 0;
}
/* body.home:not(.sub-header-is-open) .header__tel a,
body.home:not(.sub-header-is-open) .header__installation a,
body.home:not(.sub-header-is-open) #primary-menu li a,
body.home:not(.sub-header-is-open) #primary-menu li button {
	color: #fff;
} */
#mobile-menu {
	display: none;
}
/* Secondary Menu Item. */
#menu-sub-menu > li > button.opened-menu-item-primary + span.menu-icon {
	height: 20px;
	overflow: hidden;
}
#menu-sub-menu > li > button.opened-menu-item-primary + span.menu-icon span.menu-icon-inner {
	display: block;
	width: 0;
	height: 0;
	border-top: 21px solid transparent;
	border-bottom: 21px solid transparent;
	border-right: 21px solid var(--enigma-grey-tint-20);
	position: relative;
	transform: rotate(90deg);
	margin: -15.5px auto 0;
  }
#menu-sub-menu > li > button.opened-menu-item-primary + span.menu-icon span.menu-icon-inner:after {
	content: '';
	width: 0;
	height: 0;
	border-top: 20px solid transparent;
	border-bottom: 20px solid transparent;
	border-right: 20px solid var(--modulo-green-pale);
	position: absolute;
	top: -20px;
	left: 1.5px;
  }
.sub-header {
	margin: 0 auto;
	width: 100%;
	background: #fff;
	position: absolute;
	margin-top: 126px;
}
.sub-header-inner {
		display: flex;
		margin: 0 auto;
		max-width: calc(var(--inner) + 40px);
		width: 100%;
		padding: 45px 15px 45px;
		position: relative;
		z-index: 100;
		background-color: var(--modulo-green-pale);
	}
.sub-header .header-sub-menu-images {
	width: calc(25% - 50px);
	/* min-height: 400px; */
}
#menu-sub-menu-1  > li > a,
#menu-sub-menu-1  > li > button.header-sub-menu-nolink {
	display: none;
}
#menu-sub-menu-1  > li > .sub-menu > li > a,
#menu-sub-menu-1  > li > .sub-menu > li > button.header-sub-menu-nolink {
	display: block;
	margin-right: 35px;
}
.sub-header .menu-sub-menu-container {
	width: 75%;
	/* min-height: 430px; */
	display: flex;
	padding-bottom: 25px;
}
.sub-header .menu-sub-menu-container #menu-sub-menu-1 {
		margin: auto 0;
		width: 100%;
		padding-right: 30px;
	}
@media screen and (max-width: 640px) {
		.sub-header .menu-sub-menu-container #menu-sub-menu-1 {
			margin-right: 0;
			padding-right: 0;
		}
	}
#menu-sub-menu-1 .sub-menu {
	display: flex;
	flex-wrap: wrap;
}
#menu-sub-menu-1 .sub-menu li {
		width: 100%;
		max-width: 50%;
	}
@media screen and (max-width: 850px) {
	#menu-sub-menu-1  > li > .sub-menu > li > button.header-sub-menu-nolink {
		width: 100%;
		line-height: 1.42;
	}
}
@media screen and (min-width: 851px) {
	#menu-sub-menu-1  > li > .sub-menu > li > button.header-sub-menu-nolink {
		width: calc(100% - 35px);
		line-height: 1.42;
	}
}
#menu-sub-menu-1  > li > .sub-menu > li > .sub-menu {
	padding-right: 35px;
	margin: 30px 0 0 0;
}
/* End Secondary Menu Item. */
/* Menu Popup. */
.sub-header {
	position: absolute;
	left: -99999px;
	top: -99999px;
	opacity: 0;
	background-color: var(--modulo-green-pale);
}
.sub-header #menu-sub-menu-1 > li {
		display: none;
	}
.sub-header.sub-header-open {
		left: 0;
		top: 0;
		opacity: 1;
		/* transition: opacity 0.25s ease-in-out; */
		z-index: 900;
		width: 100%;
		border-top: 1px solid var(--enigma-grey-tint-20);
		border-bottom: 1px solid var(--enigma-grey-tint-20);
		max-height: calc(100vh - 100px);
		overflow-y: scroll;
	}
@media screen and (min-width: 851px) {
			.sub-header.sub-header-open {
			}
			.sub-header.sub-header-open:after {
				content: '';
				display: block;
				width: 100%;
				background-color: var(--modulo-green-pale);
				top: 0;
				left: 0;
				position: absolute;
			}
			body.sub-header-is-open::before {
				position: absolute;
				width: 100%;
				height: 100%;
				display: block;
				content: '';
				left: 0;
				top: 126px;
				background-color: rgba(0,0,0,0.6);
				z-index: 100;
			}
				body.sub-header-is-open.sticky-header-active::before {
					height: 100vh !important;
					position: fixed !important;
				}

			#header {
				position: relative;
				z-index: 101;
			}

			.sub-header-inner {
				/* min-height: 400px; */
			}

			body.sticky-header-active .sub-header.sub-header-open,
			body.sticky-header-active .sub-header.sub-header-open:after {
				height: calc(100vh - 100px) !important;
				top: 40px !important;
				position: fixed !important;
				margin-top: 0 !important;
			}
		}
@media screen and (min-width: 851px) and (max-height: 750px) {
			.sub-header.sub-header-open {
				height: calc(100vh - 126px);
				overflow: scroll;
			}
			.sub-header.sub-header-open:after {
				content: '';
				display: block;
				height: calc(100vh - 126px);
				width: 100%;
				background-color: var(--modulo-green-pale);
				top: 0;
				left: 0;
				position: absolute;
			}
		}
body.sub-header-is-open:not(.sticky-header-active) {
		position: fixed;
		width: 100%;
	}
@media screen and (min-width: 851px) {
		body.sub-header-is-open.sticky-header-active,
		html.sub-header-is-open-html.sticky-header-active {
			overflow-y: hidden !important;
			overflow-x: visible !important;
		}
	}
.sub-header #menu-sub-menu-1  .sub-nav-active {
		display: block;
	}
#menu-sub-menu-1  {
		position: relative;
	}
#menu-sub-menu-1 .sub-menu li a span:first-of-type {
		display: flex;
		flex-wrap: wrap;
	}
.header-sub-menu-title {
		order: 1;
		width: 100%;
	}
.header-sub-menu-text {
		order: 2;
		width: 100%;
	}
.header-sub-menu-title,
	#menu-sub-menu-1 .sub-menu a {
		font-size: var(--menu-sub-heading);
		font-weight: var(--menu-sub-heading-weight);
		color: var(--menu-sub-heading-colour);
		margin-bottom: 5px;
	}
.header-sub-menu-text {
		font-size: var(--menu-sub-text);
		font-weight: var(--menu-sub-text-weight);
		color: var(--menu-sub-text-colour);
		margin-bottom: 0;
	}
.sub-header #menu-sub-menu-1 .sub-menu > li {
		margin-bottom: 30px;
	}
.sub-header #menu-sub-menu-1 .sub-menu > li a:hover .header-sub-menu-title,
	.sub-header #menu-sub-menu-1 .sub-menu > li a:focus .header-sub-menu-title,
	#menu-sub-menu-1 .sub-menu > li a:hover,
	#menu-sub-menu-1 .sub-menu > li a:focus {
		color: var(--menu-sub-heading-colour-hover);
	}
/* Menu Imagery. */
.header-sub-menu-imagery__inner {
		max-width: 275px;
		position: relative;
		aspect-ratio: 11/16;
		border-radius: var(--border-radius);
		overflow: hidden;
		background-color: var(--enigma-grey-tint-20)
	}
.header-sub-menu-imagery__inner img {
			display: block;
			max-width: 100%;
			position: absolute;
			top: 0;
			left: 0;
			opacity: 0;
			transition: opacity 0.25s ease-in-out;
			border-radius: 6px;
			overflow: hidden;
			max-height: 405px;
			-o-object-fit: cover;
			   object-fit: cover;
			width: 100%;
			height: 100%;
		}
.header-sub-menu-imagery__inner img.menu-item-active-image {
			opacity: 1;
			transition: opacity 0.25s ease-in-out;
		}
.menu-item-image-link-first {
			opacity: 1 !important;
		}
/* End Menu Imagery. */
@media screen and (min-width: 851px) {
	.header #menu-header-menu-wrapper.sticky {
		position: fixed !important;
		top: 0 !important;
	}
}
/* Close Menu. */
#sub-header-menu-close {
	border: 0;
	padding: 0;
	margin: 0;
	box-shadow: none;
	display: inline-block;
	height: 35px;
    width: 35px;
    position: absolute;
    right: 15px;
    background: transparent;
    margin-top: 0;
	top: 37px;
	opacity: 1;
	transition: opacity 0.25s ease-in-out;
	display: flex;
}
#sub-header-menu-close svg {
		margin: auto;
	}
#sub-header-menu-close.sub-header-menu-close-fadeout {
		opacity: 0.5;
		transition: opacity 0.25s ease-in-out;
	}
#sub-header-menu-close svg path.sub-header-menu-close-bg {
		stroke: var(--modulo-green-primary);
		fill: transparent;
		transition: all 0.25s ease-in-out;
	}
#sub-header-menu-close:hover svg path.sub-header-menu-close-bg,
		#sub-header-menu-close:focus svg path.sub-header-menu-close-bg {
			stroke: var(--selo-blue);
			transition: all 0.25s ease-in-out;
		}
@media screen and (min-width: 851px) {
	.sub-menu-heading {
		border: 0;
		clip: rect(1px, 1px, 1px, 1px);
		-webkit-clip-path: inset(50%);
		        clip-path: inset(50%);
		height: 1px;
		margin: -1px;
		overflow: hidden;
		padding: 0;
		position: absolute;
		width: 1px;
		word-wrap: normal !important;
	}
}
.sub-nav-active .sub-menu > li > a > span {
	display: block;
	position: relative;
}
.sub-nav-active .sub-menu > li > a > span::before {
	content: '';
	display: block;
	left: -15px;
	width: 5px;
	background-color: var(--menu-sub-heading-colour-hover);
	position: absolute;
	height: calc(100% + 8px);
	top: -4px;
	opacity: 0;
	transition: opacity .25s ease-in-out;
}
.sub-nav-active .sub-menu > li > a:hover > span::before {
	opacity: 1;
	transition: opacity .25s ease-in-out;
}
/* Mobile. */
@media screen and (min-width: 961px) and (max-width: 1200px) {
	#menu-sub-menu .menu-item:first-of-type {
		display: none;
	}
	#primary-menu li a, #primary-menu li button {
		padding-left: 10px;
		padding-right: 10px;
	}
}
@media screen and (min-width: 851px) and (max-width: 960px) {
	.header__logo {
		width: 25%;
		display: flex;
	}
		/* .header__logo a {
			margin-top: auto;
			padding-bottom: 15px;
		} */
	#heading-nav {
		width: 75%;
	}
	#menu-sub-menu .menu-item:first-of-type {
		display: none;
	}
	#primary-menu li a, #primary-menu li button {
		padding-left: 5px;
		padding-right: 5px;
	}
}
/* @media screen and (max-width: 1100px) {
	#menu-sub-menu {
		display none !important;
	}

	#sub-header-menu-close,
	.header-sub-menu-images {
		display: none !important;
	}

	#menu-sub-menu-1 > li > a,
	.sub-header #menu-sub-menu-1 > li {
		display: block !important;
	}

	#menu-sub-menu-1 .sub-menu li {
		max-width: 50%;
	}

} */
@media screen and (max-width: 850px) {
	.sub-header {
		margin-top: 90px;
	}

	#menu-sub-menu,
	#sub-header-menu-close,
	.header-sub-menu-images {
		display: none !important;
	}

	#menu-sub-menu-1 > li > a,
	.sub-header #menu-sub-menu-1 > li {
		display: block !important;
	}

	.header__email span,
	.header__tel span,
	.header__installation {
		border: 0;
		clip: rect(1px, 1px, 1px, 1px);
		-webkit-clip-path: inset(50%);
		        clip-path: inset(50%);
		height: 1px;
		margin: -1px;
		overflow: hidden;
		padding: 0;
		position: absolute;
		width: 1px;
		word-wrap: normal !important;
	}

	#menu-sub-menu-1 .sub-menu li {
		max-width: 100%;
	}
	.sub-header .menu-sub-menu-container {
		width: 100%;
	}
	.sub-header #menu-sub-menu-1 .sub-menu > li {
		margin-bottom: 0;
	}
	#menu-sub-menu-1 > li > .sub-menu > li > a,
	#menu-sub-menu-1 > li > .sub-menu > li > button.header-sub-menu-nolink {
		margin-right: 0;
		min-height: 35px;
	}

	.heading-nav__top {
		margin-right: -15px;
	}
	.header__menu {
		padding-top: 15px;
	}
	.header__logo {
		/* width: 50% !important; */
		width: 30% !important;
	}
	#heading-nav {
		/* width: 45% !important; */
		margin-top: -5px;
		width: 70% !important;
	}
	.heading-nav__top {
		flex-wrap: nowrap !important;
	}
	.header__email img {
		height: 23px;
		width: 23px;
		margin: auto;
		position: relative;
		top: 3px;
	}
	.header__tel img {
		height: 24px;
		width: 24px;
		margin: auto;
		position: relative;
		top: 2px;
	}
	.header__tel {
		display: flex;
		margin-top: 2px;
	}
	.header__email a,
	.header__tel a {
		margin: auto !important;
		display: flex;
	}
	.header__mobile-button {
		display: block;
	}
	#mobile-menu {
		display: block;
		height: 45px;
		width: 45px;
		background: 0 0;
		border: 0;
		box-shadow: none;
		padding: 10px;
		margin: 0 0 0 10px;
		cursor: pointer;
	}
	#mobile-menu-open {
		display: block;
			color: var(--selo-construction-black);
	}
		#mobile-menu-open path {
			fill: var(--modulo-green-primary);
		}
	#mobile-menu-close {
		display: none;
		position: relative;
		top: -2px;
	}
	.mobile-menu-open #mobile-menu-open {
		display: none;
	}
	.mobile-menu-open #mobile-menu-close {
		display: block;
			color: var(--selo-construction-black);
	}
		.mobile-menu-open #mobile-menu-close path {
			fill: var(--modulo-green-primary);
		}
	.header__tel,
	.header__email {
		margin: -5px 10px 0;
	}

	.header__mobile-button {
		margin: -5px 4px 0;
	}

	#menu-sub-menu-1 .sub-menu {
		position: absolute;
		left: -99999px;
		top: -99999px;
		opacity: 0;
	}

	#menu-sub-menu-1 .mobile-menu-open-primary-item + .sub-menu {
		position: static;
		opacity: 1;
		margin-top: 10px;
		margin-bottom: 15px;
	}

		#menu-sub-menu-1 .mobile-menu-open-primary-item + .sub-menu li {
			margin: 0 10px 15px;
		}

		#menu-sub-menu-1 .mobile-menu-open-primary-item + .sub-menu li a {
			padding-left: 10px;
		}

		#menu-sub-menu-1 .mobile-menu-open-primary-item + .sub-menu .header-sub-menu-title {
			margin-bottom: 0;
		}

		#menu-sub-menu-1 .mobile-menu-open-primary-item + .sub-menu .header-sub-menu-text {
		}

	#menu-sub-menu-1 > li.menu-item > a,
	.sub-menu-heading {
		font-size: var(--menu-sub-heading);
		font-weight: var(--bold);
		width: 100%;
		padding: 10px 15px 10px 5px;
		text-align: left;
		margin-top: 5px;
		margin-bottom: 5px;
	}

	body.sub-header-is-open::before {
		position: absolute;
		width: 100%;
		height: 100%;
		display: block;
		content: '';
		left: 0;
		top: 126px;
		background-color: rgba(0,0,0,0.6);
		z-index: 100;
	}

	.sub-menu .header-sub-menu-title {
		font-size: 1rem;
	}
}
body.home:not(.sub-header-is-open) #mobile-menu svg path {
	fill: #fff;
}
body:not(.home) #primary-menu li.current-menu-item > a,
body.post-type-archive-projects #primary-menu li#menu-item-468 > a,
body.single-projects #primary-menu li#menu-item-468 > a,
body[class*="tax-project"] #primary-menu li#menu-item-468 > a {
	color: var(--selo-blue);
}
@media screen and (max-width: 720px) {
	#header {
		padding-top: 15px;
	}

	#heading-nav {
		margin-top: -12px;
		width: 70% !important;
	}

	#menu-main-menu li:first-of-type {
		display: none;
	}
}
@media screen and (max-width: 640px) {
	#header {
		padding-top: 10px;
	}
	.header__menu {
		padding-bottom: 5px;
	}
	#heading-nav {
		margin-top: 0px !important;
		width: 100% !important;
		position: static;
	}
	.header__logo {
		width: 60% !important;
	}
	#menu-main-menu {
		justify-content: center !important;
	}
	.heading-nav__top {
		position: absolute;
		top: 15px;
		right: 15px;
	}
	#primary-menu {
		margin-top: 20px;
	}
	#primary-menu li a {
		padding-left: 10px;
		padding-right: 10px;
	}
}

