/* ------------------------------------  */
/* ---------- SITE FRAMEWORK ----------  */
/* ------------------------------------  */


@import 'variables.php';
:root {--mainFont: "Montserrat", sans-serif;}

html { scroll-behavior: smooth; overflow-x: hidden; overflow-y: scroll; }
body { font-family: var(--mainFont); font-size: .875rem; line-height: 1.4; overflow: hidden; }
body.site-body{ background: var(--siteBackground);}
body.site-body * { box-sizing: border-box; }

.content-div { min-height: 600px; }
.ui-autocomplete { z-index: 10001 !important; }

/* DISPLAY CLASSES */
.full-width-fix { width: 100vw !important; max-width: 100vw !important; position: relative !important; left: 50%; right: 50%; margin-left: -50vw; margin-right: -50vw; }
.hidden { display: none; }
.hideImportant { display: none !important; }
.form-group{margin-bottom: 15px;}

/* SITE FORMS */
input::placeholder { font-family: inherit; }
textarea { font-family: inherit; }
select { width: 100%; border: 1px solid var(--border); height: 50px; padding: 0 10px; appearance: none; -webkit-appearance: none; -moz-appearance: none; background: url(../images/chevron-down-black.svg) no-repeat 98% center #fff; }
input[type=text], input[type=date], input[type=tel], input[type=number], input[type=email], input[type=password], textarea { width: 100%; height: 50px; background-color: #fff; border: 1px solid var(--border); padding: 0 10px; box-sizing: border-box; font-size: .875rem; color: var(--textColour); transition: 0.2s ease-in-out all; }
textarea { height: 100px; }
input::-webkit-outer-spin-button, input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input[type=number] { -moz-appearance: textfield; }
:is(input, select, textarea).input-error { border-color: #a30e0e !important; }
.site-form-field { padding: 10px 0; }
.site-form-label { font-size: 1rem; color: #3B3B3D; padding: 5px 0; }

.sr-alert { position: fixed; left: 100%; }

/* ----- TYPOGRAPHY ----- */
h1, h2, h3, h4, h5, h6 { display: block; color: var(--headingsColour); margin: 0; padding: 0 0 10px 0; font-weight: 400; line-height: 1.4;}
h1 { font-size: 2.625;}
h2 { font-size: 2.375;}
h3 { font-size: 2rem;}
h4 { font-size: 1.75;}
h5 { font-size: 1.5rem;}
h6 { font-size: 1.25rem;}
p { padding: 5px 0; font-size: 1rem; color: var(--textColour); margin: 0; }
a { text-decoration: none; color: var(--linkColour); }
p a:not([class]) {text-decoration: underline;}
a:focus-visible { background-color: #f9dc4a; color: #000; outline: 1px solid #000; }
ul { list-style-position: outside; padding: 5px 0 20px 20px; font-size: .875rem; color: var(--textColour); list-style-type: disc; }
ul li { padding: 0 0 15px 0; line-height: 20px; }
ol { list-style-position: outside; padding: 5px 0 20px 20px; font-size: .875rem; color: var(--textColour); list-style-type: decimal; }
ol li { padding: 0 0 5px 0; }
hr { color: #D8D8D8; background: #D8D8D8; height: 1px; border: 0; margin-bottom: 20px; position: relative; }

/* Button Classes */
.button-primary { display: inline-flex; align-items: center; justify-content: center; padding: 13px 20px; margin: 0; line-height: 1.4; 
    background: var(--mainColour); border: 1px solid var(--mainColour); text-align: center; color: #fff !important; text-decoration: none; 
    transition: 0.2s ease-in all; font-size: 1.063rem; font-weight: bold; border-radius: 5px; text-decoration: none; }
.button-primary:hover { background: var(--tertiaryColour); border-color: var(--tertiaryColour); text-decoration: none; }
.button-secondary { display: inline-flex; align-items: center; justify-content: center; padding: 13px 20px; margin: 0; line-height: 1.4; background: #fff; 
    border: 1px solid var(--mainColour); text-align: center; color: var(--mainColour) !important; text-decoration: none; transition: 0.2s ease-in all; 
    font-size: 1.063rem; font-weight: bold; border-radius: 5px; text-decoration: none; }
.button-secondary:hover { background: var(--tertiaryColour); border-color: var(--tertiaryColour); color: #fff !important; text-decoration: none; }

a.skiptocontent { position: absolute; top: 0; left: 0; opacity: 0; width: 1px; height: 1px; }
a.skiptocontent:focus, a.skiptocontent:active { display: flex; align-items: center; justify-content: center; height: 30px; padding: 0 20px; border: 1px solid #000; background: #f9dc4a; color: #000; font-size: .875rem; font-weight: bold; opacity: 1; width: auto; z-index: 10000; }

.empty-loader:empty { display: flex; align-items: center; justify-content: center; padding: 5px; }
.empty-loader:empty:after { content: ''; width: 20px; height: 20px; border: 2px solid #fff; border-color: var(--mainColour) transparent transparent; border-radius: 50%; animation: spin 1s infinite; }

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/*Header*/
header.site-header { position: relative; z-index: 1000; position: fixed; left: 0: top:0;}

/*-- HEADER WRAP --*/
.header-wrap {height: 100px; position:relative; }
.header-wrap .header-inner{height: 100%; display: flex; align-items: center; gap:50px; position: relative; padding: 0 40px 0 0; margin-left: calc((100vw - 1550px) / 2);}
.header-wrap .header-inner::before{content:""; background:var(--headerColour); opacity: .9; position: absolute; inset: 0; z-index: -1; border-radius:  0 0 50px 0; transition: ease-in-out all .2s;}
.header-wrap .header-inner::after{content:""; background:var(--headerColour); opacity: .9; position: absolute; top:0; bottom: 0; right: 100%; width: 100vw; z-index: -1; transition: ease-in-out all .2s;}
.header-wrap.menu-active .header-inner::before{opacity: 1; border-radius: 0;}
.header-wrap.menu-active .header-inner::after{opacity: 1;}

.header-wrap .logo {height: 100%; padding: 10px 0; display: flex;}
.header-wrap .logo a{height: 100%; display: flex; align-items: center;}
.header-wrap .logo img { max-height: 100%; max-width: 100%; width: auto; height: auto; }

.menu-toggle{height: 100%; width: 50px; display: flex; flex-direction: column; align-items: center; justify-content: center; z-index: 2000; 
    position: relative;}
.menu-toggle > div{display: flex; align-items: center; flex-direction:column; justify-content: center; height:40px; width:40px; transition: ease-in-out all .2s;}
.menu-toggle > div::before{content: ""; height: 4px; width: 40px; margin-bottom: 8px; background: var(--secondaryColour); border-radius: 4px; flex-shrink: 0;}
.menu-toggle > div::after{content: ""; height: 4px; width: 40px; margin-top: 8px; background: var(--secondaryColour); border-radius: 4px; flex-shrink: 0;}
.menu-toggle > div > div{height: 4px; width: 40px; background: var(--secondaryColour); border-radius: 4px; flex-shrink: 0;}
.menu-toggle.active > div{transform:rotate(90deg);}

/* Main Menu */
.menu-wrap{display: flex; width:100%; background: var(--mainColour); padding: 20px 20px 40px 20px; position: absolute; top: 100%; left: 0; transform: translateY(-100px); transition: ease-in-out all .2s; z-index: -1; opacity: 0; visibility: hidden;
    border-radius: 0 0 50px 0;}
.menu-wrap::before{content: ""; background:var(--headerColour); position: absolute; right: 100%; top: 0; height: 100%; width: 100vw;}
.main-menu {list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap:10px;}
.main-menu ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap:15px;}
.main-menu li{display: flex; flex-direction: column; gap:10px; padding: 0; margin: 0;}
.main-menu li a{color: #fff; font-size: 1.125rem;}
.main-menu > li > a{font-weight: bold;}
.main-menu ul li a{padding-left: 10px;}
.main-menu li a:hover{text-decoration: underline;}

.menu-wrap.active{visibility: visible; z-index: 1000; transform: translateY(0); opacity: 1;}

/*Overlay*/
.overlay { background: rgba(0, 0, 0, .6); position: fixed; top: 0; height: 100vh; width: 100%; left: 0; z-index: -1; 
    visibility: hidden; opacity: 0; transition: ease-in-out all .4s; }
.overlay.hover { visibility: visible; opacity: 1; z-index: 999; }

/*-- FOOTER WRAP --*/
.footer-wrap { background: var(--footerColour); padding:50px 0; }
.footer-wrap > div { display: flex; align-items: flex-start; }
.footer-col { flex-grow: 1; display: flex; flex-direction: column; align-items: flex-start; gap:20px;  }
.footer-col-title { color: #fff; font-weight: 600; font-size: 1.125rem; display: flex; flex-direction: column; padding: 0; line-height: 30px; gap: 10px; }
.footer-col:not(.footer-outro) .footer-col-title::after { content: ''; width: 28px; height: 3px; background: #fff; border-radius: 50px; }
.footer-outro{gap:10px;}
.footer-outro .footer-col-title { margin: 10px 0 0px 0; }

.footer-contact { font-size: .875rem; display: flex; flex-direction: column; gap: 20px; }
.footer-contact .location { display: flex; align-items: flex-start; line-height: 26px; }
.footer-contact .location:before { content: ''; width: 30px; height: 30px; background: url(../images/pin.svg) no-repeat left center; }
.footer-contact * { color: #fff; }
.footer-contact a { display: flex; align-items: center; }
.footer-contact a:hover { color: #fff; }
.footer-contact a.call:before { content: ''; width: 30px; height: 30px; background: url(../images/call.svg) no-repeat left center; }
.footer-contact a.mail:before { content: ''; width: 30px; height: 30px; background: url(../images/mail.svg) no-repeat left center; }

.footer-social { display: flex; align-items: center; gap: 15px; padding: 10px 0; }
.footer-social>a { display: block; width: 26px; height: 26px; }
.footer-social>a.fb { background: url(../images/icon-fb.svg) no-repeat center; background-size: contain; }
.footer-social>a.ig { background: url(../images/icon-ig.svg) no-repeat center; background-size: contain; }
.footer-social>a.tw { background: url(../images/icon-x.svg) no-repeat center; background-size: contain; }
.footer-social>a.li { background: url(../images/icon-in.svg) no-repeat center; background-size: contain; }
.footer-social>a.yt { background: url(../images/icon-yt.svg) no-repeat center; background-size: contain; }
.footer-social>a.tk { background: url(../images/icon-tt.svg) no-repeat center; background-size: contain; }

.footer-menu { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 25px; }
.footer-menu>li { padding: 0; margin: 0; }
.footer-menu>li>a { color: #fff; font-size: .875rem; text-decoration: none; }
.footer-menu>li>a:hover{text-decoration: underline;}
.footer-menu ul { display: none; }

/*-- BYLINE --*/
.byline-wrap { background: var(--bylineColour); padding: 30px 0;}
.byline-wrap > div { display: flex; flex-direction: column; align-items: center; padding: 0 15px; gap: 20px; }
.byline-menu { display: flex; align-items: center; justify-content: center; list-style: none; padding: 0; margin: 0; flex-wrap:wrap; row-gap:10px; }
.byline-menu>li { padding: 0 10px; line-height: 0.875rem; border-right: 1px solid #fff; }
.byline-menu>li:last-child { border: 0; }
.byline-menu>li>a { color: #fff; text-decoration: none; transition:ease-in-out all .3s; }
.byline-wrap > div > a { color: #fff; text-decoration: none; font-size:0.75rem; }

.pop-overlay { position: absolute; z-index: 10000; top: 0; left: 0; right: 0; background: rgba(0, 0, 0, 0.74); opacity: 0; display: flex; justify-content: center; }
.pop-overlay>div>a { position: absolute; width: 30px; height: 30px; background: url(../images/close.svg) no-repeat center; z-index: 5; top: 5px; right: 5px; }
.pop-overlay>div { background: #fff; position: absolute; background: #fff; padding: 20px; margin: 10px; max-width: 600px; min-width: 300px; flex: 0 0 auto; font-size: 1rem; line-height: 26px; border-radius: 5px; }
.pop-overlay.pop-image>div { max-width: 100vw; max-height: 100vh; }
.pop-overlay.pop-image>div img { max-width: 100%; max-height: 100%; }
.pop-buttons { display: flex; margin: 10px 0; align-items: center; justify-content: space-between; }

/* -- TEXT MODULE -- */
.text_module_wrap { position: relative; }
.text_module_container { position: relative; z-index: 1; }
.text_module_before { position: absolute; left: calc(-1140px / 2); width: 100vw; top: 0; height: 100%; z-index: -1; }
.text_module_after { position: absolute; width: 100vw; top: 0; height: 100%; z-index: -1; }

/* -- SPACING MODULE -- */
.spacing_module { display: flex; align-items: center; justify-content: center; background: transparent; position: relative; z-index: 1; transition: 0.2s ease-in-out all; }
.spacing_module span { opacity: 0; text-align: center; font-size: 1.5rem; font-weight: bold; transition: 0.2s ease-in-out all; }
.spacing_module.admin_logged:hover { background: #efefef; }
.spacing_module.admin_logged:hover span { opacity: 1; }

/*Fullscreen Gallery*/
.flexslider { height: auto; position: relative; }
.flexslider:not(.full-width-fix) .flex-direction-nav { display: none; }
.flex-viewport { height: 100% !important; }
.flexslider .slides { list-style: none; margin: 0; padding: 0; overflow: hidden; }
.flexslider .slides>li { display: none; -webkit-backface-visibility: hidden; position: relative; margin: 0; padding: 0; width: 100%; background-size: cover; background-repeat: no-repeat; background-position: center; height: 100%; min-height: 100px; }
.flexslider .slides { height: 100%; }
.flexslider .slides>li.flex-active-slide { display: flex !important; flex-direction: column }
.flexslider .slides>li>a { display: block; height: 100%; }
.flexslider .slides>li>img, .flexslider .slides>li>a>img { width: 100%; display: block; z-index: 4; }
.flexslider .slides:after { content: "\0020"; display: block; clear: both; visibility: hidden; line-height: 0; height: 0; }
html[xmlns] .flexslider .slides { display: block; }
* html .flexslider .slides { height: 1%; }
.no-js .flexslider .slides>li:first-child { display: block; }
.flexSliderContainer.arrow { position: relative; }
.flexSliderContainer.arrow .flexslider { margin-bottom: -30px; }
.flexSliderContainer.arrow .slides>li, .flexSliderContainer.arrow .slides>li>a { clip-path: polygon(0 calc(100% - 30px), calc(50% - 30px) calc(100% - 30px), calc(50% - 1px) 100%, calc(50% + 1px) 100%, calc(50% + 30px) calc(100% - 30px), 100% calc(100% - 30px), 100% 0, 0 0); -webkit-clip-path: polygon(0 calc(100% - 30px), calc(50% - 30px) calc(100% - 30px), calc(50% - 1px) 100%, calc(50% + 1px) 100%, calc(50% + 30px) calc(100% - 30px), 100% calc(100% - 30px), 100% 0, 0 0); }
.flexSliderContainer.parallax .slides>li { background-attachment: fixed; }
.flex-caption { display: flex; flex-direction: column; height: 100%; margin: 0 auto; gap: 30px; position: relative; z-index: 100; }
.flex-caption>div { display: flex; flex-direction: column; justify-content: center; box-sizing: border-box; height: auto; }
.flex-caption>div.background { background: rgba(5, 34, 85, 0.8); padding: 20px 40px; border-radius:20px; }
.flex-caption:empty { display: none; }
.flex-caption.halign-right { align-items: flex-end; }
.flex-caption.halign-left { align-items: flex-start; }
.flex-caption.halign-center { align-items: center; }
.flex-caption.valign-top { justify-content: flex-start; }
.flex-caption.valign-center { justify-content: center; }
.flex-caption.valign-bottom { justify-content: flex-end; padding-bottom: 40px; }

/*Fullscreen gallery paging buttons*/
.flex-control-paging { position: absolute; bottom: 20px; display: flex; left: calc(50% - 800px); width: 1600px; align-items: center; gap: 20px; 
    justify-content: center; z-index: 60; list-style: none; display: flex; align-items: center; justify-content: center; margin: 0; padding: 0 15px; }
.flex-control-paging>li { padding: 0; margin: 0; font-size: 0; display: flex; align-items: center; justify-content: center; }
.flex-control-paging>li>a { width: 20px; height: 20px; box-sizing: border-box; border: 1px solid #fff; background: var(--mainColour); transition: ease-in-out all .3s; border-radius: 50%; }
.flex-control-paging>li>a.flex-active { background: #fff; border-color: var(--mainColour);}

/*Fullscreen gallery arrows*/
.flex-direction-nav { position: absolute; top: 50%; margin: 0; padding: 0; width: 100%; list-style: none; }
.flex-direction-nav li { position: absolute; z-index: 10; top: calc(50% - 30px); width: 40px; height: 60px; cursor: pointer; transition: ease-in-out all .3s; padding: 0; left: 20px; background: rgba(255, 255, 255, 0.62); display: flex; align-items: center; justify-content: center; }
.flex-direction-nav li a { font-size: 0; display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; }
.flex-direction-nav li a:after { content: ""; height: 27px; width: 15px; background: url(../images/gallery-nav.svg) no-repeat center; }
.flex-direction-nav li.flex-nav-next { right: 20px; transform: rotate(180deg); left: initial; }
.flex-direction-nav li:hover { background: rgba(255, 255, 255, .8); }

/*Gallery Video*/
.flexslider .fg-video { position: relative; }
.flexslider .fg-video { height: 100%; }
.flexslider .fg-video>iframe { height: 60vw; min-height: 1200px; min-width: 1920px; width: 100vw; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); z-index: 9; pointer-events: none; }

/*Gallery Overlay*/
.overlay-on { position: absolute; inset: 0; z-index: 10; }

/*Contact Form*/
.contact-form { background: #fff; border: 1px solid #e1e1e1; padding: 20px; margin: 20px 0; border-radius: 3px; }
.contact-form .cf_header { color: var(--mainColour); font-weight: 700; display: flex; align-items: center; gap: 10px; font-size: 1.125rem; margin-bottom: 15px; }
.contact-form .cf-input { line-height: 30px; padding-bottom: 10px; }
.contact-form .cf-select { line-height: 30px; padding-bottom: 10px; display: inline-block; width: 100%; }
.contact-form .cf-text { font-size: 1rem; color: var(--textColour); margin-bottom: 20px; }
.contact-form :is(label, legend) { width: 100%; color: var(--textColour); font-size: 1rem; margin: 0; line-height: 26px; margin-bottom: 5px; }
.contact-form input[type=text], .contact-form input[type=email], .contact-form input[type=date], .contact-form textarea, .contact-form select { width: 100%; height: 42px; font-size: .875rem; border: 1px solid #e1e1e1; box-sizing: border-box; padding: 0 10px; transition: ease-in-out all .5s; color: var(--textColour); }
.contact-form :is(input[type=text], .contact-form input[type=email], .contact-form input[type=date], .contact-form textarea):focus { border-color: #071b3a; }
.contact-form select option { color: var(--textColour); }
.contact-form label span, .denotes span { color: #DC0D37; font-size: .75rem; position: relative; top: -5px; }
.contact-form textarea { resize: none; height: 130px; font-family: inherit; }

.contact-form :is(.cf-radiobox, .cf-checkbox) { padding-bottom: 10px; }
.contact-form :is(.cf-radiobox, .cf-checkbox) > legend{ font-size: 1rem; line-height: 1.4;}
.contact-form :is(.cf-radiobox, .cf-checkbox) > span { display: flex; align-items: center; color: var(--textCoour); font-size: .875rem; }

.contact-form :is(.cf-radiobox input[type=radio], .cf-checkbox input[type=checkbox]) { margin-right: 10px; accent-color: #071b3a; }
.contact-form .cf-validation { text-align: center; height: 0; padding: 10px 0; box-sizing: border-box; font-size: 1rem; color: var(--textColour); font-weight: bold; transition: all .2s ease-in-out; }
.contact_form_footer { display: flex; justify-content: space-between; }
.contact-form .cf-buttons { display: flex; justify-content: space-between; align-items: center; margin-top: 20px; }
.contact-form .cf-buttons a{padding-left:30px; padding-right:30px; }
.contact-form .cf-buttons .denotes { color: var(--textColour); font-size: .813rem; }
.contact-form .cf-buttons a.cf-reset { display: none; }

/*Layout Block Module*/
.block-layout-module { display: flex; flex-direction: column; al ign-items: center;}
.block-layout-module .layout-block { width: 100%; display: flex; justify-content: center;}
.block-layout-module .layout-block  > div{ margin: 0; display: flex; width: 100%;}
.block-layout-module .layout-image { width: 50%; position: relative; z-index: 5; display: flex; align-items: center; justify-content: flex-end; }
.block-layout-module .layout-image img { max-width: 100%; width: auto; height: auto; }
.block-layout-module .layout-content { width: 50%; display: flex; position: relative; }
.block-layout-module .layout-inner { width: 765px; padding: 30px 20px; display: flex; flex-direction: column; align-items: flex-start; position: relative; gap: 25px; z-index: 10; justify-content: center; }
.block-layout-module .layout-heading { display: flex; flex-direction: column; gap: 10px; }
.block-layout-module .layout-heading span { font-size: 2.375rem; position: relative; display: flex; font-weight: bold; color: var(--headingsColour); align-items: flex-start; margin: 0; }
.block-layout-module .layout-text * { font-size: 1.063rem; }
.block-layout-module .layout-bg-on{background: #fff;}
.block-layout-module .layout-bg-on.layout-width-content{padding:20px;}

/*Layout Button*/
.block-layout-module .layout-block { display: flex; align-items: center; flex-wrap: wrap; }
.block-layout-module .layout-buttons { display: flex; align-items: center; gap: 20px; }
.block-layout-module .layout-buttons a{display: flex; align-items: center; gap:10px; color: var(--mainColour); font-weight: bold; font-size: 1.125rem;}
.block-layout-module .layout-buttons span{height: 38px; width: 38px; background: var(--secondaryColour); border-radius: 100%; position: relative;}
.block-layout-module .layout-buttons span::after{content: ""; height:10px; width:10px; border:solid #fff; border-width:2px 2px 0 0; transform:rotate(45deg); position: absolute; top: calc(50% - 5px); left:13px; }

/*Layout Position*/
.block-layout-module .layout-pos-left > div { flex-direction: row-reverse; }
.block-layout-module .layout-pos-left .layout-image { justify-content: flex-start; }
.block-layout-module .layout-pos-left .layout-content { justify-content: flex-end; }
.block-layout-module .layout-pos-right .layout-content { justify-content: flex-start; }

/*Layout Video*/
.block-layout-module .layout-video { height: 500px; background-size: cover; background-repeat: no-repeat; background-position: center; border-radius: 10px; overflow: hidden;}
.block-layout-module .layout-video.reveal { cursor: pointer; }
.block-layout-module .layout-video.reveal::before{content: ""; position: absolute; inset: 0; background: rgba(5, 34, 85, 0.5); }
.block-layout-module .layout-video.reveal::after { content: ""; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 88px; height: 88px; background: url(../images/play.svg) center center no-repeat; background-size: 100% 100%; }
.block-layout-module .layout-video iframe { height: 100%; width: 100%; }

/*Layout Image Width*/
.block-layout-module .layout-block.layout-width-initial{ gap:25px;}
.block-layout-module .layout-block.layout-width-initial .layout-image{width: initial;}
.block-layout-module .layout-block.layout-width-initial .layout-content{width: initial; flex-grow: 1;}
.block-layout-module .layout-block.layout-width-initial .layout-inner{width: 100%;}

/*Layout Content Area width*/
.block-layout-module .layout-block.layout-width-skinny > div{max-width:1360px;}

/*Logo Carousel*/
.logo-carousel{ padding: 60px 0;}
.logo-carousel > div{padding: 0 15px; display: flex; flex-direction: column; gap: 40px; align-items: center;}
.logo-carousel .lm-heading{ display:flex; gap: 10px; color: var(--headingsColour); font-size:2.375rem; font-weight:bold; }
.logo-slider-wrap{width: 100%; position: relative;}
.logo-carousel .logo-box{background: #fff; display: flex; align-items: center; justify-content: center; height: 250px; border-radius: 10px; border:1px solid #E6E5E5;}
.logo-carousel .logo-box a{height: 100%; width: 100%; display: flex; align-items: center; justify-content: center;}
.logo-carousel .logo-box img{max-width: 90%; max-height: 90%;}

.logo-carousel .lm-gal-nav{position: absolute; top: calc(50% - 30px); height: 60px; width: 40px; background: transparent;}
.logo-carousel .lm-gal-nav::before{content: ""; height: 12px; width:12px; border:solid var(--tertiaryColour); border-width:3px 3px 0 0; transform: rotate(45deg);
    position: absolute; right: 16px; top: calc(50% - 6px); transition: ease-in-out all .3s;}
.logo-carousel .lm-gal-nav.lm-nav-disabled::before{opacity: .5;}
.logo-carousel .lm-gal-prev{ left:-50px; transform:rotate(180deg); }
.logo-carousel .lm-gal-next{ right:-50px; }

/*Thumbnail Gallery*/
.thumbnail-gallery{padding: 20px 0;}
.thumbnail-gallery .tg-items{display: flex; gap:20px; align-items: flex-start; flex-wrap: wrap;}
.thumbnail-gallery .tg-item{background: #fff; display: flex; align-items: center; justify-content: center; border: 1px solid #EEEBEB; 
    width: calc(25% - 15px); height: 360px; cursor: pointer;}
.thumbnail-gallery .tg-item img{ max-width:90%; max-height: 90%; height:auto; width:auto; }

/*System edit controls*/
.AB-editContentContainer { display: flex; align-items: flex-end; }
.AB-editing .__contentbox { z-index: 3000; }

/*Animation*/
@keyframes shadow-pulse {
    0% { box-shadow: 0 0 0 0px rgba(0, 0, 0, .6); }
    100% { box-shadow: 0 0 0 20px rgba(0, 0, 0, 0); }
}

@media (min-width:1600px) {
    .container { max-width: 1560px; }

}

@media (max-width:1600px) {
    /*Layout BLock*/
    .block-layout-module .layout-block.layout-width-content{width: 100%;}

    .block-layout-module .layout-block.layout-width-skinny > div{max-width: 1140px;}
}

@media (min-width:1400px) and (max-width:1600px) {
    .header-wrap .header-inner{margin-left: calc((100vw - 1310px) / 2);}

    /*Logo Carousel*/
    .logo-carousel .logo-box{height: 200px;}

}

@media (min-width:1200px) and (max-width:1399px) {
    .header-wrap .header-inner{margin-left: calc((100vw - 1130px) / 2);}

     /*Logo Carousel*/
    .logo-carousel .logo-box{height: 172px;}

    /*Layout Block*/
    .block-layout-module .layout-block.layout-width-skinny > div{max-width: 1140px;}

    /*Thumbnail Gallery*/
    .thumbnail-gallery .tg-item{height: 280px;}

}

@media (min-width:992px){
    .footer-menu-wrap{display: block !important;}
}

/*---------LARGE DESKTOP < 1199px---------*/
@media (min-width:1200px) {
    .mobile:not(.desktop-large), .tablet:not(.desktop-large), .desktop:not(.desktop-large) { display: none !important; }
    .content_wrap { min-height: 600px; }
}

/*---------DESKTOP < 1199px---------*/
@media (min-width:992px) and (max-width:1199px) {
    .mobile:not(.desktop), .tablet:not(.desktop), .desktop-large:not(.desktop) { display: none !important; }

    .header-wrap .header-inner{margin-left: calc((100vw - 950px) / 2);}

     /*Layout Block*/
    .block-layout-module .layout-inner { width: 100%; }
    .block-layout-module .layout-video {height: 260px;}
    .block-layout-module .layout-block.layout-width-skinny > div{max-width: 960px;}

     /*Logo Carousel*/
    .logo-carousel .logo-box{height: 225px;}
    .logo-carousel .lm-gal-prev{left: -40px;}
    .logo-carousel .lm-gal-next{right: -40px;}

    /*Thumbnail Gallery*/
    .thumbnail-gallery .tg-item{height:215px; }
}

/*---------Tablet & Mobile---------*/
@media (max-width:991px) {


    /* ----- MODULES ----- */

    /* -- Fullscreen Gallery -- */
    .flex-direction-nav li { left: 0; }
    .flex-direction-nav li.flex-nav-next { right: 0; }
    .footer-container .footer-col:last-child { width: 100%; display: flex; flex-direction: column; flex: 0 0 auto; align-items: center; text-align: center; gap: 20px; }
    .footer-container .footer-col:last-child .footer-col-title { display: none; }
    .footer-container .footer-col:last-child .footer-social { justify-content: center; }
}

/*---------TABLET < 959px---------*/
@media (min-width:768px) and (max-width:991px) {
    .mobile:not(.tablet), .desktop:not(.tablet), .desktop-large:not(.tablet) { display: none !important; }
    .tablet-hidden { display: none !important; }

    /*Header*/
    .header-wrap{height: 85px;}
    .header-wrap .header-inner{margin-left: calc((100vw - 720px) / 2); padding-right: 30px; gap:30px;}
    .header-wrap .header-inner::before, .menu-wrap{border-radius: 0 0 20px 0;}

    /*Footer*/
    .footer-wrap > div{flex-wrap: wrap; row-gap:30px; display: flex;}
    .footer-col{flex-grow: initial; width: calc(100%/3)}
    .footer-outro{width: 100%; align-items: center;}

    /*Text Module*/
    .text_module_before { left: calc(-768px / 2); }
    .header-wrap>div>a { margin-left: auto; }

    /*Layout Block*/
    .block-layout-module .layout-block { align-items: flex-start; }
    .block-layout-module .layout-heading span{ font-size: 1.375rem; }
    .block-layout-module .layout-inner { width: 100%; gap:15px;}
    .block-layout-module .layout-video{height: 190px;}
    .block-layout-module .layout-block.layout-width-skinny > div{max-width: 720px;}

    /*Thumbnail Gallery*/
    .thumbnail-gallery .tg-item{height:155px; }
}
@media (max-width:767px) {
    .tablet:not(.mobile), .desktop:not(.mobile), .desktop-large:not(.mobile), .mobile-hidden { display: none !important; }
    h1 { font-size: 2.375rem; }
    h2 { font-size: 2.125rem; }
    h3 { font-size: 1.75rem; }
    h4 { font-size: 1.5rem; }
    h5 { font-size: 1.25rem; }
    h6 { font-size: 1rem; }
    p { font-size: .875rem; padding: 5px 0 15px 0; }
    img { max-width: 100%; vertical-align: middle; }

    .button-primary, .button-secondary{font-size: 0.938rem; padding: 12px 15px; }

    /*Header*/
    .header-wrap{height: 65px;}
    .header-wrap .logo img{max-width: 150px;}
    .header-wrap .header-inner{margin-left:0; padding: 0 15px; gap:20px;}
    .header-wrap .header-inner::before{border-radius: 0 0 20px 0;}
    .menu-toggle > div{width: 30px;}
    .menu-toggle > div::after{width: 30px; height: 3px; margin-top: 5px;}
    .menu-toggle > div::before{width: 30px; height: 3px; margin-bottom: 5px;}
    .menu-toggle > div > div{width: 30px; height: 3px;}
    .menu-wrap{border-radius: 0 0 20px 0;}
    .main-menu li a{font-size: 0.875rem;}

    /*Footer*/
    .footer-wrap > div{flex-direction: column; gap:0;}
    .footer-wrap .footer-intro{margin-bottom: 20px; width: 100%;}
    .footer-wrap .footer-menu-container{width: 100%; text-align: left; align-items: flex-start; gap:0; border-bottom: 1px solid transparent; 
        transition: ease-in-out all .3s;}
    .footer-wrap .footer-menu-container h4::after{content: none !important;}
    .footer-wrap .footer-menu-container h4{position: relative; line-height: 50px; border-bottom: 1px solid rgba(255, 255, 255, .4); width: 100%;}
    .footer-wrap .footer-menu-container h4::before{content: ""; height:8px; width:8px; border: solid #fff; border-width: 0 2px 2px 0; position:absolute; 
        right:14px; top:calc(50% - 4px); transition: ease-in-out all .3s; transform: rotate(45deg); }
    .footer-wrap .footer-menu-wrap{padding: 10px 0 20px 0; display: none;}
    .footer-wrap .footer-menu-container.active{ border-bottom: 1px solid rgba(255, 255, 255, .4);}
    .footer-wrap .footer-menu-container.active h4{border-bottom: 1px solid transparent;}
    .footer-wrap .footer-menu-container.active h4::before{transform: rotate(225deg);}
    .footer-wrap #footer-header-2{border-top: 1px solid rgba(255, 255, 255, .4); }
    .footer-wrap .footer-outro{align-items: center; margin-top: 30px; width: 100%;}

    /*Fullscreen Gallery*/
    .full-width-fix .flex-caption.halign-center {  width: 300px; max-width: 100%; }
    .full-width-fix .flex-caption.halign-left {  width: 300px; max-width: 100%; }
    .full-width-fix .flex-caption.halign-right { width: 300px; max-width: 100%; }
    .flex-control-paging { left: 0; width: 100%; padding: 0 10px; }
    .flex-caption>div.background { padding: 20px; }
    .flex-direction-nav li { width: 21px; height: 32px; }
    .flex-direction-nav li a:after { width: 8px; height: 14px; background-size: contain; }

    /*Contact Form*/
    .contact-form { padding: 20px 10px; }
    .contact-form .cf-text { font-size: .875rem; margin-bottom: 10px; }
    .contact-form :is(label, legend) { font-size: .875rem; }
    .contact-form .cf-buttons { flex-direction: column; align-items: flex-start; gap: 10px; }
    .contact-form .cf-buttons a { margin-left: auto; }

    /*Text Module*/
    .text_module_before { left: calc(-320px / 2); }

    /*Layout Module*/
    .block-layout-module { gap: 0; }
    .block-layout-module .layout-block > div { flex-direction: column; padding: 0; gap: 24px; align-items:center; }
    .block-layout-module :is(.layout-image, .layout-content) { width: 100%; }
    .block-layout-module .layout-image { justify-content: center !important; }
    .block-layout-module .layout-inner { width: 100%; padding: 0 10px 24px; gap: 15px; text-align:center; align-items: center;}
    .block-layout-module .layout-heading span { font-size: 1.375rem; }
    .block-layout-module .layout-text *{ font-size: .875rem; padding: 0; margin: 0; }
    .block-layout-module .layout-video{height: 160px; width: 290px;}

    .block-layout-module .layout-block.layout-bg-on .layout-image{padding: 20px 0 0 0;}
    .block-layout-module .layout-block.layout-width-content{gap:20px;}
    .block-layout-module .layout-block.layout-width-content .layout-content{width: 100%; flex: initial;}

    /*Logo Carousel*/
    .logo-carousel{padding: 40px 0;}
    .logo-carousel .lm-heading{font-size: 1.875rem;}
    .logo-carousel .logo-box{height: 150px;}

    /*Thumbnail Gallery*/
    .thumbnail-gallery > div{padding: 0 10px;}
    .thumbnail-gallery .tg-items{flex-direction: column; align-items: center;}
    .thumbnail-gallery .tg-item{width:300px; height: 300px;}
}
