/*=====================================================*/
/*===========        THEME :: ALPHA       =============*/
/*=====================================================*/
:root {
  --color-neutral-100: #fff;
  --color-neutral-200: #f5f5f5;
  --color-neutral-300: #e4e4e4;
  --color-neutral-400: #d3d3d3;
  --color-neutral-500: #c2c2c2;
  --color-neutral-600: #a1a1a1;
  --color-neutral-700: #666;
  --color-neutral-800: #222;
  --color-neutral-900: #000;
  --font-color-light: #fff;
  --font-color-dark: #000;
  --surface-color-light: #fff;
  --surface-color-dark: #000;
  --color-primary: #343434;
  --color-secondary: #fff6ed;
  --color-accent-1: #d6621e;
  --color-accent-2: #FFB81C;
  --color-accent-1-darker: #cf8e00;
  --color-accent-2-darker: #623f1c;
  --color-warning: #ff8f00;
  --color-error: #ee433d;
  --color-success: #2cb61d;
  --box-shadow-200: 0 0 20px rgba(0, 0, 0, 0.1);
  --font-color: var(--font-color-dark);
  --heading-color: var(--color-accent-1);
  --link-bg-color: transparent;
  --link-color: var(--font-color-dark);
  --link-border-color: var(--color-accent-1);
  --link-bg-color-hover: transparent;
  --link-color-hover: var(--font-color-dark);
  --link-border-color-hover: var(--color-accent-1);
  --list-style-color: var(--color-accent-1);
  --border-color: var(--color-primary);
  --header-bg-color: var(--color-accent-1);
  --nav-bg-color: var(--color-primary);
  --nav-submenu-bg-color: var(--color-secondary);
  --nav-item-bg-color: var(--surface-color-light);
  --nav-item-color: inherit;
  --nav-item-bg-color-hover: var(--color-accent-1);
  --nav-item-color-hover: var(--font-color-light);
  --nav-toggle-bg-color: var(--color-accent-1);
  --nav-toggle-bg-color-hover: var(--color-accent-1);
  --nav-hamburger-color: var(--font-color-light);
  --nav-item-border-color-hover: var(--color-primary);
  --frm-ctrl-label-bg-color: var(--color-accent-1);
  --frm-ctrl-label-color: var(--font-color-light);
  --frm-ctrl-bg-color: transparent;
  --frm-ctrl-border-color: var(--color-accent-1);
  --frm-ctrl-border-color-focus: var(--color-accent-1-darker);
  --frm-ctrl-box-shadow-focus: var(--box-shadow-200);
  --frm-val-confirm-border-color: var(--color-accent-1);
  --frm-val-confirm-icon-color: var(--color-warning);
  --body-bg-color: var(--color-neutral-300);
  --body-container-bg-color: var(--color-neutral-100);
  --main-container-bg-color: var(--color-neutral-200);
  --grad-clr-5: #00455d;
  --color-primary-gradient: linear-gradient(to bottom, var(--grad-clr-5), var(--color-primary));
  --color-primary-gradient-2: linear-gradient(to bottom right, var(--grad-clr-5), var(--color-primary));
  --grad-clr-1: #c59c5d;
  --grad-clr-2: #ac7840;
  --grad-clr-3: #95511f;
  --grad-clr-4: #883d0a;
  --base-gradient-1: linear-gradient(to bottom, var(--grad-clr-1), var(--grad-clr-4));
  --base-gradient-2: linear-gradient(to bottom right, var(--grad-clr-1), var(--grad-clr-4));
  --base-gradient-2-reverse: linear-gradient(to bottom right, var(--grad-clr-4), var(--grad-clr-1));
  --grayscale-gradient: linear-gradient(to bottom, #5d5d5d, #252525);
  --base-gradient-3: linear-gradient(to bottom right, #0aefef, #3807f5);
  --base-gradient-4: linear-gradient(135deg, #4facfe, #00f2fe);
  --heading-gradient: var(--base-gradient-1);
  --list-style-gradient: var(--base-gradient-2);
  --border-gradient: var(--base-gradient-2);
  --nav-toggle-gradient: var(--base-gradient-2);
  --nav-toggle-gradient-hover: var(--base-gradient-2-reverse);
  --block-1-gradient: linear-gradient(to bottom, var(--color-primary) 65%, #2d2d2d 100%);
  --block-1-bg-color: var(--block-1-gradient);
  --block-1-font-color: var(--font-color-light);
  --block-2-clr-1: #f7eee2;
  --block-2-bg-color: var(--block-2-clr-1);
  --block-2-font-color: var(--font-color-dark);
  --block-3-clr-1: #f1e2d0;
  --block-3-bg-color: var(--block-3-clr-1);
  --block-3-font-color: var(--font-color-dark);
  --block-4-clr-1: #cbac86;
  --block-4-clr-2: #9b7c5a;
  --block-4-gradient: linear-gradient(to bottom, var(--block-4-clr-1), var(--block-4-clr-2));
  --block-4-bg-color: var(--block-4-clr-2);
  --block-4-bg-color: var(--block-4-gradient);
  --block-4-font-color: var(--font-color-light);
}
:root {
  --body-container-max-width: 2000px;
  --content-container-max-width: 1400px;
  --block-container-max-width-xs: 600px;
  --block-container-max-width-sm: 800px;
  --block-container-max-width-md: 1000px;
  --block-container-max-width-lg: 1200px;
  --block-container-max-width-xl: 1700px;
  --block-spacing-sm: 25px;
  --block-spacing-md: 50px;
  --block-spacing-lg: 100px;
  --block-spacing-xl: 150px;
  --item-spacing: clamp(25px, 4vw, 50px);
  --btn-border-width: 2px;
  --btn-border-radius: 5px;
  --img-border-radius: 25px;
}
/*.set-margin-bottom() {
    @media @not-mobile-large {
        margin-bottom: @item-margin-sm;
    }

    @media @mobile-large {
        margin-bottom: @item-margin-md;
    }

    @media @laptop {
        margin-bottom: @item-margin-lg;
    }

    @media @desktop {
        margin-bottom: @item-margin-xl;
    }

    &:last-child {
        margin-bottom: 0;
    }
}*/
/* Resets (also using Normalize.css) */
/*-----------------------------------------------------*/
html {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
*,
*::before,
*::after {
  -webkit-box-sizing: inherit;
  -moz-box-sizing: inherit;
  box-sizing: inherit;
}
html,
body {
  overflow-x: hidden;
  position: relative;
}
body,
p,
h1,
h2,
h3,
h4,
h5,
h6 {
  padding: 0;
  margin: 0;
}
b,
strong {
  font-weight: bold;
}
img {
  display: block;
  width: 100%;
  height: auto;
}
input,
select,
textarea,
button,
html [type="button"] {
  border-radius: 0;
}
input[type=text],
input[type=email],
input[type=password],
textarea {
  -webkit-appearance: none;
}
/* Typography */
/*-----------------------------------------------------*/
html {
  font-size: 16px;
}
body {
  font-family: 'Montserrat', sans-serif;
  font-weight: 300;
  font-optical-sizing: auto;
  color: var(--font-color);
  line-height: 1.7;
  letter-spacing: normal;
  font-size: clamp(1.125rem, 0.1289vw + 1.0425rem, 1.1875rem);
}
@media (max-width: 767px) {
  body {
    line-height: 1.6;
  }
}
body.smaller-font {
  font-size: clamp(0.9375rem, 0.208vw + 0.890625rem, 1.125rem);
}
body.bigger-font {
  font-size: clamp(1.0625rem, 0.208vw + 1.015625rem, 1.25rem);
}
body.biggest-font {
  font-size: clamp(1.125rem, 0.208vw + 1.078125rem, 1.3125rem);
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Urbanist', sans-serif;
  font-weight: 200;
  line-height: 1.2;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: clamp(25px, 4vw, 50px) 0;
}
p {
  margin-bottom: 15px;
}
@media (min-width: 1024px) {
  p {
    margin-bottom: 25px;
  }
}
a {
  color: inherit;
  text-decoration: none;
}
.smaller {
  font-size: smaller;
}
h1 {
  font-size: clamp(3rem, calc(2.1rem + 2.5vw), 5rem);
}
h2 {
  font-size: clamp(2.25em, calc(1.53em + 2.125vw), 3.57em);
}
h3 {
  font-size: clamp(2em, calc(1.26em + 1.75vw), 2.94em);
}
h4 {
  font-size: clamp(1.75em, calc(0.99em + 1.375vw), 2.31em);
}
h5,
h6 {
  font-size: clamp(1.5em, calc(0.72em + 1vw), 1.68em);
}
b,
strong {
  font-weight: 500;
}
/* Font Icons - Icofont */
/*-----------------------------------------------------*/
@font-face {
  font-family: 'IcoFont';
  src: url('/_assets/fonts/icofont.woff2') format('woff2'), url('/_assets/fonts/icofont.woff') format('woff');
  font-weight: normal;
  font-style: "Regular";
}
.semps-icon {
  font-family: 'IcoFont' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  line-height: 1;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
}
.semps-icon-arrow-left:before {
  content: '\ea5c';
}
.semps-icon-arrow-right:before {
  content: '\ea5d';
}
.semps-icon-arrow-up:before {
  content: '\ea5e';
}
.semps-icon-success:before {
  content: '\f00e';
}
.semps-icon-exclamation:before {
  content: '\ef19';
}
.semps-icon-close:before {
  content: '\eedd';
}
.semps-icon-photo:before {
  content: '\eece';
}
.semps-icon-video:before {
  content: '\eca7';
}
.semps-icon-date:before {
  content: '\eecd';
}
.semps-icon-time:before {
  content: '\eedc';
}
.semps-icon-category:before {
  content: '\efbe';
}
.semps-icon-authorm:before {
  content: '\ecf8';
}
.semps-icon-authorf:before {
  content: '\ed10';
}
.semps-icon-quote-left:before {
  content: '\efcd';
}
.semps-icon-quote-right:before {
  content: '\efce';
}
.semps-icon-address:before {
  content: '\ef79';
}
.semps-icon-email:before {
  content: '\ef12';
}
.semps-icon-phone:before {
  content: '\ec8a';
}
.semps-icon-web:before {
  content: '\f028';
}
.semps-icon-social:before {
  content: '\ec84';
}
.semps-icon-social-email:before {
  content: '\ec56';
}
.semps-icon-social-facebook:before {
  content: '\ed37';
}
.semps-icon-social-google-plus:before {
  content: '\ed43';
}
.semps-icon-social-instagram:before {
  content: '\ed46';
}
.semps-icon-social-linkedin:before {
  content: '\ed4d';
}
.semps-icon-social-pinterest:before {
  content: '\ed5d';
}
.semps-icon-social-skype:before {
  content: '\ed67';
}
.semps-icon-social-twitter:before {
  content: '\ed7a';
}
.semps-icon-social-whatsapp:before {
  content: '\ed86';
}
.semps-icon-social-yelp:before {
  content: '\ed89';
}
.semps-icon-social-youtube:before {
  content: '\ed8b';
}
/* Site Custom */
/*-----------------------------------------------------*/
@media (min-width: 1024px) {
  footer .contact-details > .title {
    width: 7.5em;
    margin-left: auto;
  }
}
/* News Flash items - position can be inline, fixed to top, or fixed to bottom of page */
/* ------------------------------------------------------------ */
#bulletin {
  line-height: 1.5;
  padding: 0 15px;
  background-color: #ffd700;
}
#bulletin.inline-top {
  display: none;
}
#bulletin.inline-top.show {
  transition: margin 1s ease;
}
#bulletin.fixed-top {
  position: fixed;
  width: 100%;
  z-index: 104;
  top: 0;
  box-shadow: 0 -1px 12px rgba(0, 0, 0, 0.25);
  margin-top: -200px;
  transition: margin 0.5s ease 0.15s;
}
#bulletin.fixed-top.show {
  margin-top: 0;
  transition-delay: 2.5s;
  transition-duration: 1s;
}
#bulletin.fixed-bottom {
  position: fixed;
  width: 100%;
  z-index: 101;
  bottom: 0;
  box-shadow: 0 1px 12px rgba(0, 0, 0, 0.25);
  margin-bottom: -200px;
  transition: margin 0.5s ease 0.15s;
}
#bulletin.fixed-bottom.show {
  margin-bottom: 0;
  transition-delay: 2.5s;
  transition-duration: 1s;
}
@media (min-width: 768px) {
  #bulletin {
    padding: 0 25px;
  }
}
@media (min-width: 1024px) {
  #bulletin {
    padding: 0 50px;
  }
}
@media (min-width: 1367px) {
  #bulletin {
    padding: 0 100px;
  }
}
#bulletin .container {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
  min-height: 60px;
}
#bulletin .msg {
  flex-grow: 1;
  text-align: center;
}
#bulletin .msg p:last-child {
  margin-bottom: 0;
}
#bulletin .dismiss {
  cursor: pointer;
  margin-left: 15px;
  transition: all 0.15s ease;
}
#bulletin .dismiss .semps-icon {
  font-size: 2em;
}
#bulletin .dismiss:hover {
  color: var(--color-primary);
}
/* Button Wrapper  */
/*-----------------------------------------------------*/
.btn-items .flex-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  flex-wrap: wrap;
  margin: -12.5px;
}
.btn-items .flex-container .btn {
  margin: 12.5px;
}
/* Buttons  */
/*-----------------------------------------------------*/
.btn {
  position: relative;
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  text-align: center;
  line-height: inherit;
  text-decoration: none;
  border-radius: var(--btn-border-radius);
  cursor: pointer;
  transition: all 0.1s ease;
}
.btn.btn-sml {
  min-width: 120px;
  padding: clamp(5px, 0.5vw, 10px) clamp(10px, 1.5vw, 30px);
}
.btn.btn-med {
  min-width: 160px;
  padding: clamp(10px, 1vw, 15px) clamp(20px, 2.5vw, 40px);
}
.btn.btn-lrg {
  min-width: 200px;
  padding: clamp(15px, 1.5vw, 20px) clamp(30px, 3.5vw, 50px);
}
/* Button Colours  */
/*-----------------------------------------------------*/
.btn-clr {
  color: var(--btn-color, inherit);
  background: var(--btn-bg-color, transparent);
  border: var(--btn-border-width) solid var(--btn-border-color, transparent);
}
.btn-clr:hover {
  color: var(--btn-color-hover, inherit);
  background: var(--btn-bg-color-hover, transparent);
  border-color: var(--btn-border-color-hover, transparent);
}
.btn-clr.btn-clr-1 {
  --btn-bg-color: var(--color-accent-1);
  --btn-color: var(--font-color-light);
  --btn-border-color: var(--color-accent-1);
  --btn-bg-color-hover: transparent;
  --btn-border-color-hover: var(--color-accent-1);
}
.btn-clr.btn-clr-1-inverse {
  --btn-bg-color: transparent;
  --btn-border-color: var(--color-accent-1);
  --btn-bg-color-hover: var(--color-accent-1);
  --btn-color-hover: var(--font-color-light);
  --btn-border-color-hover: var(--color-accent-1);
}
.btn-clr.btn-clr-2 {
  --btn-bg-color: var(--color-primary);
  --btn-color: var(--font-color-light);
  --btn-border-color: var(--color-primary);
  --btn-bg-color-hover: transparent;
  --btn-border-color-hover: var(--color-primary);
}
.btn-clr.btn-clr-2-inverse {
  --btn-bg-color: transparent;
  --btn-border-color: var(--color-primary);
  --btn-bg-color-hover: var(--color-primary);
  --btn-color-hover: var(--font-color-light);
  --btn-border-color-hover: var(--color-primary);
}
.btn-grad {
  border: none;
  background: transparent;
  z-index: 1;
  overflow: hidden;
}
.btn-grad::before,
.btn-grad::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--btn-bg-gradient);
  transition: inherit;
}
.btn-grad::before {
  opacity: var(--btn-bg-gradient-opacity);
}
.btn-grad::after {
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  border-radius: inherit;
  padding: var(--btn-border-width);
  opacity: var(--btn-border-gradient-opacity);
}
.btn-grad:hover::before {
  opacity: var(--btn-bg-gradient-opacity-hover);
}
.btn-grad:hover::after {
  opacity: var(--btn-border-gradient-opacity-hover);
}
.btn-grad.btn-clr-1 {
  --btn-bg-gradient: var(--base-gradient-2);
  --btn-bg-gradient-opacity: 1;
  --btn-border-gradient-opacity: 0;
  --btn-bg-gradient-opacity-hover: 0;
  --btn-border-gradient-opacity-hover: 1;
}
.btn-grad.btn-clr-1-inverse {
  --btn-bg-gradient: var(--base-gradient-2);
  --btn-bg-gradient-opacity: 0;
  --btn-border-gradient-opacity: 1;
  --btn-bg-gradient-opacity-hover: 1;
  --btn-border-gradient-opacity-hover: 0;
}
.btn-grad.btn-clr-2 {
  --btn-bg-gradient: var(--color-primary-gradient);
  --btn-bg-gradient-opacity: 1;
  --btn-border-gradient-opacity: 0;
  --btn-bg-gradient-opacity-hover: 0;
  --btn-border-gradient-opacity-hover: 1;
}
.btn-grad.btn-clr-2-inverse {
  --btn-bg-gradient: var(--color-primary-gradient);
  --btn-bg-gradient-opacity: 0;
  --btn-border-gradient-opacity: 1;
  --btn-bg-gradient-opacity-hover: 1;
  --btn-border-gradient-opacity-hover: 0;
}
.btn.btn-grad.btn-sml {
  padding: calc(clamp(5px, 0.5vw, 10px) + 2px) calc(clamp(10px, 1.5vw, 30px) + 2px);
}
.btn.btn-grad.btn-med {
  padding: calc(clamp(10px, 1vw, 15px) + 2px) calc(clamp(20px, 2.5vw, 40px) + 2px);
}
.btn.btn-grad.btn-lrg {
  padding: calc(clamp(15px, 1.5vw, 20px) + 2px) calc(clamp(30px, 3.5vw, 50px) + 2px);
}
/* Link style buttons  */
/*-----------------------------------------------------*/
.btn.btn-lnk {
  font-weight: 300;
}
.btn.lnk-sml {
  padding: 0;
}
.btn.lnk-med {
  padding: 5px 10px;
}
.btn.lnk-lrg {
  padding: 10px 15px;
}
.btn.lnk-clr {
  color: var(--link-color);
  background-color: var(--link-bg-color);
  border-bottom: 1px dashed var(--link-border-color);
}
.btn.lnk-clr:hover {
  color: var(--link-color-hover);
  background-color: var(--link-bg-color-hover);
  border-bottom: 1px solid var(--link-border-color-hover);
}
.btn.lnk-clr.lnk-clr-1 {
  --link-border-color: var(--color-accent-1);
  --link-border-color-hover: var(--color-accent-1);
}
.btn.lnk-clr.lnk-clr-2 {
  --link-border-color: var(--color-primary);
  --link-border-color-hover: var(--color-primary);
}
/* Backoffice RTE's  */
/*-----------------------------------------------------*/
.theme-wrapper {
  margin-bottom: clamp(25px, 4vw, 50px);
  margin-bottom: clamp(25px, 4vw, 75px);
}
.theme-wrapper a:not(.btn) {
  color: var(--link-color);
  background-color: var(--link-bg-color);
  border-bottom: 1px dashed var(--link-border-color);
}
.theme-wrapper a:not(.btn):hover {
  color: var(--link-color-hover);
  background-color: var(--link-bg-color-hover);
  border-bottom: 1px solid var(--link-border-color-hover);
}
.theme-wrapper ul {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-bottom: 15px;
}
@media (min-width: 1024px) {
  .theme-wrapper ul {
    margin-bottom: 25px;
  }
}
.theme-wrapper ul li {
  position: relative;
  padding-left: 50px;
  margin-bottom: 15px;
}
@media (min-width: 1024px) {
  .theme-wrapper ul li {
    margin-bottom: 20px;
  }
}
.theme-wrapper ul li::before {
  position: absolute;
  top: 0;
  left: 0;
  font-family: 'IcoFont';
  content: '\ec77';
  color: var(--list-style-color);
  padding-left: 2px;
}
.theme-wrapper ul > *:first-child {
  margin-top: 0;
}
.theme-wrapper ul > *:last-child {
  margin-bottom: 0;
}
.theme-wrapper table {
  width: 100%;
  border-spacing: 0;
}
.theme-wrapper table td {
  width: 50%;
  padding: 20px 25px;
}
@media (max-width: 479px) {
  .theme-wrapper table tr {
    display: flex;
    flex-direction: column;
    padding: 15px;
  }
  .theme-wrapper table tr td {
    width: 100%;
    padding: 0;
  }
  .theme-wrapper table tr td:nth-child(odd) {
    font-weight: bold;
  }
}
.theme-wrapper > *:first-child {
  margin-top: 0;
}
.theme-wrapper > *:last-child {
  margin-bottom: 0;
}
body.semps-icon-bullet-1 .theme-wrapper ul li {
  padding-left: 50px;
}
body.semps-icon-bullet-1 .theme-wrapper ul li::before {
  content: '\ea69';
  font-size: 34px;
  line-height: 30px;
}
body.semps-icon-bullet-2 .theme-wrapper ul li {
  padding-left: 50px;
}
body.semps-icon-bullet-2 .theme-wrapper ul li::before {
  content: '\ea98';
  font-size: 34px;
  line-height: 30px;
}
body.semps-icon-bullet-3 .theme-wrapper ul li {
  padding-left: 50px;
}
body.semps-icon-bullet-3 .theme-wrapper ul li::before {
  content: '\ef4e';
  font-size: 34px;
  line-height: 30px;
}
body.semps-icon-bullet-4 .theme-wrapper ul li {
  padding-left: 50px;
}
body.semps-icon-bullet-4 .theme-wrapper ul li::before {
  content: '\f003';
  font-size: 34px;
  line-height: 30px;
}
body.semps-icon-bullet-6 .theme-wrapper ul li {
  padding-left: 50px;
}
body.semps-icon-bullet-6 .theme-wrapper ul li::before {
  content: '\f000';
  font-size: 30px;
  line-height: 28px;
}
body.semps-icon-bullet-7 .theme-wrapper ul li {
  padding-left: 50px;
}
body.semps-icon-bullet-7 .theme-wrapper ul li::before {
  content: '\eac0';
  font-size: 34px;
  line-height: 30px;
}
body.semps-icon-bullet-8 .theme-wrapper ul li {
  padding-left: 50px;
}
body.semps-icon-bullet-8 .theme-wrapper ul li::before {
  content: '\eac4';
  font-size: 34px;
  line-height: 30px;
}
body.semps-icon-bullet-9 .theme-wrapper ul li {
  padding-left: 50px;
}
body.semps-icon-bullet-9 .theme-wrapper ul li::before {
  content: '\f00d';
  font-size: 34px;
  line-height: 30px;
}
/* Forms  */
/*-----------------------------------------------------*/
@media (max-width: 1023px) {
  .form-wrapper {
    margin-bottom: 25px;
  }
}
.form-wrapper > div:last-child,
.form-wrapper > div:last-child > *:last-child {
  margin-bottom: 0;
}
.form-wrapper .ctrl-wrapper {
  display: flex;
  margin-bottom: 10px;
}
@media (max-width: 1023px) {
  .form-wrapper .ctrl-wrapper label {
    width: 30%;
  }
  .form-wrapper .ctrl-wrapper .ctrl {
    width: 70%;
  }
}
@media (min-width: 1024px) {
  .form-wrapper .ctrl-wrapper label {
    width: 25%;
  }
  .form-wrapper .ctrl-wrapper .ctrl {
    width: 75%;
  }
}
.form-wrapper .ctrl-wrapper label {
  font-family: 'Urbanist', sans-serif;
  font-weight: 200;
  color: var(--frm-ctrl-label-color);
  text-align: center;
  padding: 20px;
  background-color: var(--frm-ctrl-label-bg-color);
  border-bottom: 2px solid var(--frm-ctrl-border-color);
}
.form-wrapper .ctrl-wrapper .ctrl {
  font-family: 'Montserrat', sans-serif;
  color: inherit;
  padding: 15px 10px;
  background-color: var(--frm-ctrl-bg-color);
  border: none;
  border-bottom: 2px solid var(--frm-ctrl-border-color);
  transition: box-shadow 0.2s ease;
}
.form-wrapper .ctrl-wrapper .ctrl:hover,
.form-wrapper .ctrl-wrapper .ctrl:focus {
  background: none;
  outline: none;
  background-color: var(--frm-ctrl-bg-color-focus);
  border-color: var(--frm-ctrl-border-color-focus);
  box-shadow: var(--frm-ctrl-box-shadow-focus);
}
.form-wrapper textarea {
  resize: vertical;
}
.btn-items.btn-submit-items {
  display: flex;
  margin-top: 35px;
  flex-direction: column;
}
.btn-items.btn-submit-items button {
  width: 100%;
  min-height: 70px;
}
/* Invisible RECAPTCHA badge overrides */
/*-----------------------------------------------------*/
.g-recaptcha-wrapper {
  height: 60px;
  margin-top: 25px;
  margin-left: auto;
  margin-right: auto;
}
.grecaptcha-badge {
  box-shadow: none !important;
}
/* Form feedback */
/*-----------------------------------------------------*/
#validation-summary,
#form-result {
  scroll-margin-top: 25px;
}
.validation-summary-valid {
  display: none;
}
.validation-summary-errors {
  color: red;
}
.validation-summary-errors ul {
  margin-top: -5px;
  margin-bottom: 25px;
  padding-left: 20px;
}
.alert-success,
.alert-fail {
  font-family: 'Urbanist', sans-serif;
  font-weight: 200;
  color: var(--font-color-light);
  position: relative;
  padding: 20px 20px 20px 75px;
  margin-bottom: 25px;
  border-radius: 4px;
}
.alert-success::after,
.alert-fail::after {
  font-family: 'IcoFont';
  font-size: 30px;
  line-height: 30px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 25px;
}
.alert-success a,
.alert-fail a {
  color: var(--font-color-light);
  border-bottom: 2px solid var(--font-color-light);
}
.alert-success {
  background-color: var(--color-success);
}
.alert-success::after {
  content: '\f00e';
}
.alert-fail {
  background-color: var(--color-error);
}
.alert-fail::after {
  content: '\eee4';
}
/* Grids */
/*-----------------------------------------------------*/
.grid-items {
  display: grid;
  gap: 1.5em;
}
@media (max-width: 1023px) {
  .grid-items {
    grid-template-columns: 1fr;
  }
}
@media (min-width: 1024px) {
  .grid-items {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 1200px) {
  .grid-items.cols-3 {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media (min-width: 1367px) {
  .grid-items.cols-4 {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}
.grid-items .item .item-txt {
  padding: var(--grid-item-spacing) 0;
}
.grid-items .item.item-clr .item-txt {
  padding: var(--grid-item-spacing);
}
.grid-items .item.pad-item {
  padding: var(--grid-item-spacing);
}
.grid-items .item.pad-item .item-media {
  margin-bottom: var(--grid-item-spacing);
}
.grid-items .item.pad-item .item-txt {
  padding: 0;
}
/* Hover Effects  */
/*-----------------------------------------------------*/
.hover-txt-1 {
  text-decoration-line: underline;
  text-decoration-color: transparent;
  text-decoration-thickness: 3px;
  text-underline-offset: .2em;
  text-decoration-skip-ink: none;
  transition: text-decoration-color 0.2s ease;
}
.hover-txt-1:hover {
  text-decoration-color: var(--color-accent-1);
}
.hover-txt-child-1 .title {
  text-decoration-line: underline;
  text-decoration-color: transparent;
  text-decoration-thickness: 3px;
  text-underline-offset: .2em;
  text-decoration-skip-ink: none;
  transition: text-decoration-color 0.2s ease;
}
.hover-txt-child-1:hover .title {
  text-decoration-color: var(--color-accent-1);
}
.hover-txt-2 {
  background-image: var(--base-gradient-2);
  background-size: 0% 2px;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  transition: background-size 0.15s;
}
.hover-txt-2:hover {
  background-size: 100% 2px;
}
.hover-txt-child-2 .title span {
  background-image: var(--base-gradient-2);
  background-size: 0% 2px;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  transition: background-size 0.15s;
}
.hover-txt-child-2:hover .title span {
  background-size: 100% 2px;
}
.hover-img-1 {
  position: relative;
  overflow: hidden;
}
.hover-img-1 .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background-image: radial-gradient(rgba(0, 0, 0, 0.25), #000);
  opacity: 0.25;
  transition: all 0.5s ease;
}
.hover-img-1 img {
  transition: all 0.2s ease;
}
.hover-img-1:hover .overlay {
  opacity: 0;
}
.hover-img-1:hover img {
  transform: scale(1.1);
}
.hover-img-child-1 .item-img {
  position: relative;
  overflow: hidden;
}
.hover-img-child-1 .item-img .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background-image: radial-gradient(rgba(0, 0, 0, 0.25), #000);
  opacity: 0.25;
  transition: all 0.5s ease;
}
.hover-img-child-1 .item-img img {
  transition: all 0.2s ease;
}
.hover-img-child-1:hover .item-img .overlay {
  opacity: 0;
}
.hover-img-child-1:hover .item-img img {
  transform: scale(1.1);
}
.hover-overlay-child-1 {
  overflow: hidden;
}
.hover-overlay-child-1 .item-txt {
  transition: all 0.35s;
}
.hover-overlay-child-1:hover .item-txt {
  transform: translateY(100%);
  opacity: 0;
}
/* Images */
/*-----------------------------------------------------*/
.img-ratio {
  position: relative;
}
.img-ratio img {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
}
.img-ratio.img-1-1,
.img-ratio.img-square {
  padding-top: 100%;
}
.img-ratio.img-circle {
  padding-top: 100%;
  border-radius: 50%;
  overflow: hidden;
}
.img-ratio.img-4-3 {
  padding-top: 75%;
}
.img-ratio.img-3-2 {
  padding-top: 66.7%;
}
.img-ratio.img-16-10 {
  padding-top: 62.5%;
}
.img-ratio.img-16-9 {
  padding-top: 56.25%;
}
.img-ratio.img-3-4 {
  padding-top: 133%;
}
.img-ratio.img-2-3 {
  padding-top: 150%;
}
.img-ratio.img-10-16 {
  padding-top: 160%;
}
.img-ratio.img-9-16 {
  padding-top: 177%;
}
.cover img {
  object-fit: cover;
}
.contain img {
  object-fit: contain;
}
.cover-photo img,
.cover-video img {
  object-fit: cover;
}
.contain-photo img,
.contain-video img {
  object-fit: contain;
}
.item-media a {
  display: block;
}
.item-img {
  border-radius: var(--img-border-radius);
  overflow: hidden;
}
@media (min-width: 1600px) {
  .txt-bigger > .item-title,
  .txt-bigger > .theme-wrapper {
    font-size: 1.1em;
  }
  .txt-biggest > .item-title,
  .txt-biggest > .theme-wrapper {
    font-size: 1.2em;
  }
}
/* Focus */
/*-----------------------------------------------------*/
a:focus,
button:focus {
  outline: none !important;
}
/* Alignment */
/*-----------------------------------------------------*/
.left {
  text-align: left;
}
.center {
  text-align: center;
}
.right {
  text-align: right;
}
/* Block Alignment */
/*-----------------------------------------------------*/
.block-left {
  margin-right: auto;
}
.block-center {
  margin-left: auto;
  margin-right: auto;
}
.block-right {
  margin-left: auto;
}
/* Flexbox Alignment */
/*-----------------------------------------------------*/
.flex-left {
  justify-content: flex-start;
}
.flex-center {
  justify-content: center;
}
.flex-right {
  justify-content: flex-end;
}
/* Horizontal Rule */
/*-----------------------------------------------------*/
hr {
  border: 0;
  border-top: 4px solid var(--color-accent-1);
  width: 35%;
  margin: clamp(25px, 4vw, 75px) 0;
}
/* Handle Text Overflow. I mainly use this to stop long email addresses from overflowing on small devices */
/* --------------------------------------------------- */
.ellipses {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
/* Feature text styles */
/*-----------------------------------------------------*/
.feature-text {
  font-size: clamp(1.25rem, 3cqw, 1.55rem);
  font-weight: 400;
  text-align: center;
  border-block: 4px solid var(--color-accent-1);
  padding-block: clamp(25px, 4.5cqw, 35px);
  margin-bottom: clamp(35px, 6.5cqw, 50px);
}
/*-----------------------------------------------------*/
/* Page Highlight */
/*-----------------------------------------------------*/
.highlight-text {
  position: relative;
  font-weight: 500;
  margin: clamp(25px, 3.5vw, 50px) 0;
  border-radius: 25px;
  background-color: rgba(255, 255, 255, 0.05);
  box-shadow: 0 0 50px rgba(0, 0, 0, 0.08);
}
.highlight-text:before {
  position: absolute;
  font-family: 'IcoFont';
  content: '\ef4e';
  font-size: 3.5em;
  line-height: 1em;
  color: var(--color-accent-1-darker);
  border-radius: 50%;
}
@media (max-width: 479px) {
  .highlight-text {
    padding: 25px;
    padding-top: 90px;
    overflow-x: auto;
    text-align: center;
  }
  .highlight-text:before {
    left: 50%;
    transform: translateX(-50%);
    top: 20px;
  }
}
@media (min-width: 480px) {
  .highlight-text {
    padding: clamp(30px, 3.5vw, 50px);
    padding-left: clamp(105px, 10vw, 140px);
  }
  .highlight-text:before {
    top: 50%;
    transform: translateY(-50%);
    left: clamp(25px, 2.65vw, 40px);
  }
}
/* For scroll to "top of page" */
/*-----------------------------------------------------*/
#to-top {
  position: fixed;
  bottom: 10px;
  right: 10px;
  z-index: 100;
  visibility: hidden;
  opacity: 0;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.15s ease;
  --btn-color: #8c8c8c;
  --btn-border-color: #8c8c8c;
}
#to-top .semps-icon {
  font-size: 2em;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
}
#to-top.show {
  visibility: visible;
  opacity: 1;
}
/* Custom CSS and overrides for "Owl Carousel" plugin */
/*-----------------------------------------------------*/
.owl-carousel .owl-nav .btn {
  border-radius: 50%;
}
.owl-carousel .owl-nav .btn > .icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media (max-width: 1023px) {
  .owl-carousel .owl-nav .btn {
    padding: clamp(20px, 3.5vw, 28px);
  }
  .owl-carousel .owl-nav .btn > .icon {
    font-size: clamp(1.5em, 5vw, 2em);
  }
}
@media (min-width: 1024px) {
  .owl-carousel .owl-nav .btn {
    padding: clamp(28px, 2.2vw, 35px);
  }
  .owl-carousel .owl-nav .btn > .icon {
    font-size: clamp(2em, 3.2vw, 2.5em);
  }
}
@media (max-width: 1023px) {
  .owl-carousel.owl-nav-center .owl-nav {
    display: flex;
    justify-content: center;
  }
  .owl-carousel.owl-nav-center .owl-nav .btn {
    margin: 10px 5px;
  }
}
@media (min-width: 1024px) {
  .owl-carousel.owl-nav-center .owl-nav .btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }
  .owl-carousel.owl-nav-center .owl-nav .btn.btn-left {
    left: clamp(-60px, -3.2vw, -45px);
  }
  .owl-carousel.owl-nav-center .owl-nav .btn.btn-right {
    right: clamp(-60px, -3.2vw, -45px);
  }
}
.owl-nav .btn-clr.btn-clr-1 {
  --btn-bg-color: var(--base-gradient-2);
  --btn-bg-color-hover: var(--base-gradient-2-reverse);
  --btn-color-hover: var(--font-color-light);
  border-width: 0;
}
@media (max-width: 1023px) {
  .owl-carousel.wider {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    padding: 0 clamp(10px, 2.8vw, 30px);
  }
}
/* Videos -  */
/*-----------------------------------------------------*/
.video-placeholder {
  position: relative;
  cursor: pointer;
}
.video-placeholder .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  z-index: 1;
  color: #fff;
  font-size: 1.5em;
  font-weight: 600;
  opacity: 0.95;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.25), 0 0 100px #000000;
}
.video-placeholder .overlay i {
  font-size: 2em;
}
.video-placeholder .overlay:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: radial-gradient(rgba(0, 0, 0, 0.25), #000000);
  opacity: 0.35;
  z-index: -1;
  transition: opacity 0.5s ease;
}
.video-placeholder .overlay:hover:before {
  opacity: 0;
}
@media (min-width: 1367px) {
  .video-placeholder .overlay {
    flex-direction: row;
    font-size: 1.8em;
  }
  .video-placeholder .overlay i {
    margin-right: 15px;
  }
}
@keyframes animateVideoPlayIcon {
  50% {
    transform: scale(1.1);
  }
}
body {
  background-color: var(--body-bg-color);
}
body > .container {
  max-width: var(--body-container-max-width);
  margin: 0 auto;
  background-color: var(--body-container-bg-color);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
body > .container > main {
  flex-grow: 1;
}
/* Header Wrapper */
/*-----------------------------------------------------*/
#header-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999;
  max-width: var(--body-container-max-width);
  left: 50%;
  transform: translateX(-50%);
}
#header-wrapper #pre-header {
  position: absolute;
  z-index: 1;
  right: 0;
  --bg-color: transparent;
}
#header-wrapper #header {
  --bg-color: transparent;
}
#header-wrapper #header .header-row {
  align-items: flex-start;
}
/* Quick contacts (sits above header) */
/*-----------------------------------------------------*/
#pre-header {
  padding: 0;
  margin: 0;
}
@media (min-width: 1024px) {
  #pre-header {
    padding: 0 clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-md));
  }
}
@media (min-width: 1024px) {
  #pre-header > .container > .item {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    align-items: center;
  }
}
#pre-header .quick-contacts {
  display: flex;
  font-size: 0.9em;
}
@media (max-width: 1023px) {
  #pre-header .quick-contacts {
    flex-wrap: wrap;
    justify-content: center;
  }
}
@media (min-width: 1024px) {
  #pre-header .quick-contacts {
    margin-right: -15px;
  }
}
#pre-header .quick-contacts a {
  color: inherit;
}
#pre-header .quick-contacts .item {
  display: flex;
  align-items: center;
  margin: 5px 10px;
}
@media (min-width: 480px) {
  #pre-header .quick-contacts .item {
    margin: 10px 15px;
  }
}
@media (max-width: 767px) {
  #pre-header .quick-contacts .item:last-child {
    display: none;
  }
}
#pre-header .quick-contacts .icon {
  font-size: 30px;
  line-height: 1;
}
#pre-header .quick-contacts .icon.phone,
#pre-header .quick-contacts .icon.address {
  margin-left: -5px;
  margin-right: 8px;
}
#pre-header .quick-contacts .icon.email {
  margin-right: 12px;
}
#pre-header .quick-contacts .text a:hover {
  color: var(--link-color-hover);
  background-color: var(--link-bg-color-hover);
  border-bottom: 1px solid var(--link-border-color-hover);
}
@media (max-width: 767px) {
  #pre-header .quick-contacts .text {
    display: none;
  }
}
/* Header */
/*-----------------------------------------------------*/
#header {
  padding: 0;
  margin: 0;
}
@media (min-width: 1367px) {
  #header {
    padding: 0 clamp(15px, 1.4vw, var(--block-spacing-sm));
  }
}
#header .header-row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  position: relative;
}
@media (min-width: 1024px) {
  #header .header-row {
    align-items: flex-end;
  }
}
#header .header-row .logo-wrapper {
  z-index: 103;
}
#header .header-row .logo-wrapper a {
  display: block;
  padding: clamp(10px, 2.5vw, 25px);
}
@media (min-width: 1367px) {
  #header .header-row .logo-wrapper a {
    padding: 35px;
  }
}
#header .header-row .logo-wrapper a img {
  width: clamp(220px, 24vw, 340px);
}
@media (min-width: 1367px) {
  #header .header-row .logo-wrapper {
    margin-left: -25px;
  }
}
#header .header-row > .feature-btn {
  position: absolute;
  top: 0;
}
@media (max-width: 479px) {
  #header .header-row > .feature-btn {
    right: 15px;
  }
}
@media (min-width: 480px) {
  #header .header-row > .feature-btn {
    right: clamp(25px, 6vw, 50px);
  }
}
@media (min-width: 1024px) {
  #header .header-row > .feature-btn {
    right: 0;
  }
}
#header .header-row > .feature-btn .btn {
  font-family: 'Urbanist', sans-serif;
  font-weight: 200;
  padding: clamp(5px, 1vw, 12px) clamp(15px, 3vw, 25px);
}
/* Main Navigation Wrapper */
/*-----------------------------------------------------*/
@media (max-width: 1023px) {
  .nav-wrapper {
    width: 100%;
    position: relative;
    top: 0;
    left: 0;
  }
}
@media (min-width: 1024px) {
  .nav-wrapper {
    margin-left: auto;
  }
}
/* Main Navigation */
/*-----------------------------------------------------*/
nav.main ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
nav.main a {
  display: block;
  font-weight: 400;
  font-size: 1em;
  line-height: 1.2;
}
@media (min-width: 1024px) {
  nav.main a {
    font-size: clamp(1em, 1.4vw, 1.2em);
  }
}
@media (max-width: 1023px) {
  nav.main {
    position: absolute;
    width: 100%;
    z-index: 102;
    background: var(--nav-bg-color);
    box-shadow: 8px 8px 15px -10px rgba(0, 0, 0, 0.25);
  }
  nav.main ul.nav-topmenu {
    display: none;
  }
  nav.main ul.nav-topmenu > li > a {
    padding: 15px 25px;
  }
  nav.main ul.nav-submenu a {
    padding: 15px;
    padding-left: 30px;
  }
  nav.main ul.nav-submenu {
    display: none;
  }
  nav.main ul.nav-submenu.open {
    display: block;
  }
}
@media (min-width: 1024px) {
  nav.main ul.nav-topmenu {
    display: flex !important;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
  }
  nav.main ul.nav-topmenu > li > a {
    padding: 15px clamp(15px, 1.65vw, 25px);
    white-space: nowrap;
  }
  nav.main ul.nav-submenu {
    position: absolute;
    min-width: 300px;
    box-shadow: 8px 8px 15px -10px rgba(0, 0, 0, 0.25);
    z-index: 102;
    margin-top: 10px;
  }
  nav.main ul.nav-submenu li a {
    padding: 15px;
  }
  nav.main ul.nav-submenu {
    visibility: hidden;
    opacity: 0;
    transform: translateY(-15px);
    transition: all 0.2s ease-in-out;
  }
  nav.main ul.nav-submenu.open {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
  }
}
@media (max-width: 1023px) {
  nav.main {
    padding: 15px 0;
  }
}
@media (min-width: 1024px) {
  nav.main {
    margin-top: 25px;
  }
}
nav.main a {
  --nav-topmenu-item-bg-color-hover: var(--color-accent-1);
  --nav-item-border-color-hover: var(--color-accent-1);
  position: relative;
}
nav.main a::after {
  content: '';
  position: absolute;
  left: 20px;
  bottom: 5px;
  height: 3px;
  width: 0;
  background: var(--nav-item-border-color-hover, transparent);
  opacity: 0;
  transition: all .2s;
}
@media (min-width: 1024px) {
  nav.main a::after {
    left: 50%;
    transform: translateX(-50%);
  }
}
nav.main a:hover::after {
  width: calc(100% - (20px * 2));
  opacity: 1;
}
@media (min-width: 1024px) {
  nav.main a:hover::after {
    width: calc(100% - (clamp(15px, 1.65vw, 25px) * 2));
  }
}
nav.main ul.nav-submenu {
  background: var(--color-primary-gradient);
}
@media (min-width: 1024px) {
  nav.main ul.nav-submenu {
    padding: 5px 0;
  }
}
@media (max-width: 1023px) {
  nav.main ul.nav-submenu li a:hover::after {
    width: calc(100% - 55px);
    left: calc(50% + 12.5px);
  }
}
@media (min-width: 1024px) {
  nav.main ul.nav-submenu li a:hover::after {
    width: calc(100% - (15px * 2));
  }
}
@media (max-width: 1023px) {
  .nav-wrapper {
    position: absolute;
    right: 0;
    width: calc(100% - 28px);
    top: auto;
    left: auto;
  }
  nav.main {
    z-index: 998;
    top: 15px;
    right: 15px;
    max-width: 350px;
    border-radius: 10px;
    overflow: hidden;
    transform: translateX(calc(100% + 15px));
    transition: transform 0.4s ease;
  }
  nav.main.open {
    transform: translateX(0);
  }
  nav.main ul.nav-topmenu {
    display: block;
  }
  nav.main ul.nav-topmenu > li > a {
    padding: 15px 25px;
  }
  nav.main ul.nav-submenu {
    background: none;
  }
  nav.main ul.nav-submenu a {
    padding-left: 40px;
  }
}
/* Main Navigation Open/Close Toggle */
/*-----------------------------------------------------*/
.nav-toggle-wrapper {
  width: 80px;
  height: 85px;
  display: flex;
  align-items: center;
  z-index: 999;
}
@media (min-width: 1024px) {
  .nav-toggle-wrapper {
    display: none;
  }
}
.nav-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  margin: 0 auto;
  cursor: pointer;
  transition: background-color 0.25s ease;
  background-color: var(--nav-toggle-bg-color);
}
.nav-toggle .nav-hamburger {
  display: block;
  position: relative;
  width: 33px;
  height: 3px;
  transform-origin: center;
  transition: all 0.25s ease-in-out;
}
.nav-toggle .nav-hamburger:before,
.nav-toggle .nav-hamburger:after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  transition: all 0.25s ease-in-out;
}
.nav-toggle .nav-hamburger:before {
  top: -9px;
}
.nav-toggle .nav-hamburger:after {
  bottom: -9px;
}
.nav-toggle:hover {
  background-color: var(--nav-toggle-bg-color-hover);
}
.nav-toggle .nav-hamburger {
  background-color: var(--nav-hamburger-color);
}
.nav-toggle .nav-hamburger:before,
.nav-toggle .nav-hamburger:after {
  background-color: inherit;
}
.nav-toggle.open .nav-hamburger {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.nav-toggle.open .nav-hamburger:before {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  top: 0;
}
.nav-toggle.open .nav-hamburger:after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  bottom: 0;
}
/* Footer */
/*-----------------------------------------------------*/
footer.block.block-clr-1 {
  padding: clamp(var(--block-spacing-md), 8vw, var(--block-spacing-lg)) clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-md));
  padding-bottom: 35px !important;
}
footer > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 1023px) {
  footer > .container {
    max-width: var(--block-container-max-width-sm);
  }
}
@media (min-width: 1024px) {
  footer > .container {
    max-width: var(--block-container-max-width-xl);
  }
}
footer .grid-items.cols-3 {
  display: grid;
  row-gap: 15px;
  column-gap: 15px;
}
@media (max-width: 1023px) {
  footer .grid-items.cols-3 {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 3em;
  }
  footer .grid-items.cols-3 .item {
    text-align: center;
  }
}
@media (min-width: 1024px) {
  footer .grid-items.cols-3 {
    grid-template-columns: 2fr 3fr 2fr;
    align-items: center;
  }
  footer .grid-items.cols-3 > .item-2 {
    text-align: center;
  }
  footer .grid-items.cols-3 > .item-3 {
    text-align: right;
  }
}
footer .grid-items.cols-3 > .item > *:first-child {
  margin-top: 0;
}
footer .grid-items.cols-3 > .item > *:last-child {
  margin-bottom: 0;
}
footer .grid-items.cols-4 {
  display: grid;
  row-gap: 15px;
  column-gap: 15px;
}
@media (max-width: 1023px) {
  footer .grid-items.cols-4 {
    grid-template-columns: 1fr;
    justify-items: center;
    row-gap: 35px;
  }
  footer .grid-items.cols-4 .item {
    text-align: center;
  }
}
@media (min-width: 1024px) {
  footer .grid-items.cols-4 {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}
footer .grid-items.cols-4 > .item > *:first-child {
  margin-top: 0;
}
footer .grid-items.cols-4 > .item > *:last-child {
  margin-bottom: 0;
}
footer h4 {
  line-height: 1.4;
  margin-bottom: 25px;
}
footer section {
  margin: clamp(25px, 4vw, 50px) 0;
}
footer section a:not(.img-link) {
  border-bottom: 1px solid transparent;
  transition: all 0.15s ease;
}
footer section a:not(.img-link):hover {
  color: var(--link-color-hover);
  background-color: var(--link-bg-color-hover);
  border-bottom: 1px solid var(--link-border-color-hover);
}
footer section > *:first-child {
  margin-top: 0;
}
footer section > *:last-child {
  margin-bottom: 0;
}
body.footer-reveal > .container {
  margin-bottom: 655px;
}
body.footer-reveal footer {
  position: fixed;
  width: 100%;
  bottom: 0;
  left: 0;
  z-index: -1;
}
/* Footer Site Logo */
/*-----------------------------------------------------*/
footer .business-logo {
  width: clamp(200px, 18vw, 260px);
}
footer .business-logo a {
  display: block;
}
/* Footer Page Links */
/*-----------------------------------------------------*/
footer .page-links h4 {
  font-size: clamp(1.75em, calc(0.99em + 1.375vw), 2.2em);
  display: inline-block;
  line-height: 1.4;
  border-bottom: 2px solid var(--color-accent-1);
  border-image: var(--base-gradient-2) 1;
}
footer .page-links ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
footer .page-links ul li {
  margin-bottom: 15px;
}
footer .page-links ul li:last-child {
  margin-bottom: 0;
}
footer .page-links ul li a {
  display: inline-block;
  border-bottom: 1px solid transparent;
}
footer .page-links ul li a:hover {
  border-color: rgba(255, 255, 255, 0.25);
}
footer .page-links > *:first-child {
  margin-top: 0;
}
footer .page-links > *:last-child {
  margin-bottom: 0;
}
/* Footer Contact Details */
/*-----------------------------------------------------*/
footer .contacts > .items {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}
footer .contacts > .items .icon-item {
  display: inline-flex;
  align-items: center;
  gap: 1.25em;
}
footer .contacts > .items a.icon-item:hover {
  background-color: transparent;
  border-bottom: 0;
}
footer .contacts .semps-icon {
  font-size: 1.6em;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 58px;
  height: 58px;
  border-radius: 50%;
}
footer .contacts .semps-icon .icon-lg {
  font-size: 1.8em;
  width: 62px;
  height: 62px;
  border-radius: 50%;
}
/* Footer Social Icons */
/*-----------------------------------------------------*/
footer .socials > .items {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.5em;
}
footer .socials > .items a {
  display: inline-block;
  border-radius: 50%;
  transition: all 0.15s ease;
}
footer .socials .semps-icon {
  font-size: 1.8em;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  border-radius: 50%;
}
/* Footer Trading Hours */
/*-----------------------------------------------------*/
footer .trading-hours {
  display: inline-grid;
  grid-template-columns: auto auto;
  column-gap: 15px;
  row-gap: 2px;
}
footer .trading-hours > div:nth-child(odd) {
  text-align: right;
}
footer .trading-hours > div:nth-child(even) {
  text-align: left;
}
/* Footer Site Meta */
/*-----------------------------------------------------*/
footer .footer-meta {
  margin-top: clamp(50px, 10vw, 85px);
}
footer .footer-meta > *:first-child {
  margin-top: 0;
}
footer .footer-meta > *:last-child {
  margin-bottom: 0;
}
footer .footer-meta-msg .meta-msg {
  text-align: center;
  background-color: rgba(0, 0, 0, 0.1);
  padding: 10px;
  border-radius: 4px;
}
footer .footer-meta-items {
  font-size: 0.8em;
  font-weight: 200;
  opacity: 0.6;
}
footer .footer-meta-items .meta-items {
  display: flex;
  flex-wrap: wrap;
}
@media (max-width: 1023px) {
  footer .footer-meta-items .meta-items {
    justify-content: center;
  }
}
footer .footer-meta-items .meta-items .item {
  white-space: nowrap;
}
footer .footer-meta-items .meta-items .item::after {
  content: '|';
  margin: 0 10px;
}
footer .footer-meta-items .meta-items .item:last-child::after {
  content: none;
}
/* Common Block styles */
/*-----------------------------------------------------*/
.block {
  margin: clamp(var(--block-spacing-md), 8vw, var(--block-spacing-xl)) clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-md));
}
.block.block-clr-1,
.block.block-clr-2,
.block.block-clr-3,
.block.block-clr-4,
.block.block-clr-5,
.block.block-clr-6 {
  margin: 0;
  padding: clamp(var(--block-spacing-md), 8vw, var(--block-spacing-xl)) clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-md));
}
.block .title-1 {
  display: flex;
  flex-direction: column;
  gap: 1em;
  margin-bottom: clamp(25px, 4vw, 75px);
}
.block .title-1 .supplement {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.4em, 3.5vw, 1.8em);
  font-weight: 300;
  letter-spacing: -0.05em;
  margin: 0;
}
.block .title-1.sup-below {
  flex-direction: column-reverse;
}
.block .title-1.sup-below .supplement {
  margin-left: 0;
}
.block .title-1 .main {
  margin-top: 0;
}
.block .title-1 h2.main {
  font-size: clamp(2.5em, calc(1.8em + 2.5vw), 4.2em);
}
.block .title-1 > *:first-child {
  margin-top: 0;
}
.block .title-1 > *:last-child {
  margin-bottom: 0;
}
.block .item-txt > *:first-child,
.block .item-txt .item-content > *:first-child {
  margin-top: 0;
}
.block .item-txt > *:last-child,
.block .item-txt .item-content > *:last-child {
  margin-bottom: 0;
}
.block > .title {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.block > .title.left {
  max-width: 1400px;
  text-align: left;
}
@media (min-width: 1024px) {
  .block > .title.left {
    padding-right: 10%;
  }
}
.block.block-img {
  position: relative;
  z-index: 0;
  background-position: center;
  background-size: cover;
  overflow: hidden;
}
.block.block-img > .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  pointer-events: none;
}
.block-clr,
.item-clr {
  background: var(--bg-color);
  color: var(--font-color);
}
.block-clr .title-1 .main span,
.item-clr .title-1 .main span {
  color: var(--title-color, inherit);
  background: var(--title-bg-color, transparent);
}
.block-clr .title-1 .supplement,
.item-clr .title-1 .supplement {
  color: var(--supplement-color, var(--heading-color, inherit));
  background: var(--supplement-bg-color, transparent);
}
:is(.block-clr-1, .item-clr-1) {
  --bg-color: var(--block-1-bg-color);
  --font-color: var(--block-1-font-color);
  --heading-color: var(--block-1-font-color);
  --title-color: var(--block-1-font-color);
  --title-bg-color: transparent;
  --supplement-color: var(--block-1-font-color);
  --supplement-bg-color: transparent;
  --link-bg-color: transparent;
  --link-color: var(--block-1-font-color);
  --link-border-color: var(--color-accent-1);
  --link-bg-color-hover: transparent;
  --link-color-hover: var(--block-1-font-color);
  --link-border-color-hover: var(--color-accent-1);
  --list-style-color: var(--color-accent-1);
}
:is(.block-clr-2, .item-clr-2) {
  --bg-color: var(--block-2-bg-color);
  --font-color: var(--block-2-font-color);
  --heading-color: var(--color-accent-1);
  --title-color: var(--color-accent-1);
  --title-bg-color: transparent;
  --supplement-color: var(--color-accent-1);
  --supplement-bg-color: transparent;
  --link-bg-color: transparent;
  --link-color: var(--block-2-font-color);
  --link-border-color: var(--color-accent-1);
  --link-bg-color-hover: transparent;
  --link-color-hover: var(--block-2-font-color);
  --link-border-color-hover: var(--color-accent-1);
  --list-style-color: var(--color-accent-1);
}
:is(.block-clr-3, .item-clr-3) {
  --bg-color: var(--block-3-bg-color);
  --font-color: var(--block-3-font-color);
  --heading-color: var(--color-accent-1);
  --title-color: var(--color-accent-1);
  --title-bg-color: transparent;
  --supplement-color: var(--color-accent-1);
  --supplement-bg-color: transparent;
  --link-bg-color: transparent;
  --link-color: var(--block-3-font-color);
  --link-border-color: var(--color-accent-1);
  --link-bg-color-hover: transparent;
  --link-color-hover: var(--block-3-font-color);
  --link-border-color-hover: var(--color-accent-1);
  --list-style-color: var(--color-accent-1);
}
:is(.block-clr-4, .item-clr-4) {
  --bg-color: var(--block-4-bg-color);
  --font-color: var(--block-4-font-color);
  --heading-color: var(--block-4-font-color);
  --title-color: var(--block-2-clr-1);
  --title-bg-color: transparent;
  --supplement-color: var(--block-4-font-color);
  --supplement-bg-color: transparent;
  --link-bg-color: transparent;
  --link-color: var(--block-4-font-color);
  --link-border-color: var(--block-2-clr-1);
  --link-bg-color-hover: transparent;
  --link-color-hover: var(--block-4-font-color);
  --link-border-color-hover: var(--block-2-clr-1);
  --list-style-color: var(--block-2-clr-1);
}
.block-clr-1 .btn-clr-1,
.block .item-clr-1 .btn-clr-1,
.block-clr-4 .btn-clr-1,
.block .item-clr-4 .btn-clr-1,
.block-clr-1 .btn-clr-2,
.block .item-clr-1 .btn-clr-2,
.block-clr-4 .btn-clr-2,
.block .item-clr-4 .btn-clr-2,
.block-clr-1 .btn-clr-3,
.block .item-clr-1 .btn-clr-3,
.block-clr-4 .btn-clr-3,
.block .item-clr-4 .btn-clr-3,
.block-clr-1 .btn-clr-4,
.block .item-clr-1 .btn-clr-4,
.block-clr-4 .btn-clr-4,
.block .item-clr-4 .btn-clr-4,
.block-clr-1 .btn-clr-5,
.block .item-clr-1 .btn-clr-5,
.block-clr-4 .btn-clr-5,
.block .item-clr-4 .btn-clr-5 {
  --btn-color-hover: var(--font-color-light);
}
.block-clr-2 .btn-clr-1,
.block .item-clr-2 .btn-clr-1,
.block-clr-3 .btn-clr-1,
.block .item-clr-3 .btn-clr-1,
.block-clr-2 .btn-clr-2,
.block .item-clr-2 .btn-clr-2,
.block-clr-3 .btn-clr-2,
.block .item-clr-3 .btn-clr-2,
.block-clr-2 .btn-clr-3,
.block .item-clr-2 .btn-clr-3,
.block-clr-3 .btn-clr-3,
.block .item-clr-3 .btn-clr-3,
.block-clr-2 .btn-clr-4,
.block .item-clr-2 .btn-clr-4,
.block-clr-3 .btn-clr-4,
.block .item-clr-3 .btn-clr-4,
.block-clr-2 .btn-clr-5,
.block .item-clr-2 .btn-clr-5,
.block-clr-3 .btn-clr-5,
.block .item-clr-3 .btn-clr-5 {
  --btn-color-hover: var(--font-color-dark);
}
.block-clr-1 {
  --nav-submenu-bg-color: var(--color-primary);
  --nav-item-bg-color: transparent;
  --nav-item-color: var(--font-color-light);
  --nav-item-bg-color-hover: var(--color-accent-1);
  --nav-item-color-hover: var(--font-color-light);
  --nav-toggle-bg-color: var(--color-accent-1);
  --nav-toggle-bg-color-hover: var(--color-accent-1);
  --nav-hamburger-color: var(--font-color-light);
}
.block-clr-2 {
  --nav-submenu-bg-color: var(--color-secondary);
  --nav-item-bg-color: var(--color-secondary);
  --nav-item-color: var(--font-color-dark);
  --nav-item-bg-color-hover: var(--color-accent-1);
  --nav-item-color-hover: var(--font-color-light);
  --nav-toggle-bg-color: var(--color-accent-1);
  --nav-toggle-bg-color-hover: var(--color-accent-1);
  --nav-hamburger-color: var(--font-color-light);
}
.block-clr-3 {
  --nav-submenu-bg-color: var(--color-accent-1);
  --nav-item-bg-color: var(--color-accent-1);
  --nav-item-color: var(--font-color-light);
  --nav-item-bg-color-hover: var(--color-primary);
  --nav-item-color-hover: var(--font-color-light);
  --nav-toggle-bg-color: var(--color-primary);
  --nav-toggle-bg-color-hover: var(--color-primary);
  --nav-hamburger-color: var(--font-color-light);
}
.txt-block-1 .item-clr,
.txt-block-2 .item-clr,
.form-block .item-clr {
  padding: clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-lg));
}
/* Text Block - Layout 1 */
/*-----------------------------------------------------*/
.txt-block-1 > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1024px) {
  .txt-block-1 > .container {
    max-width: var(--block-container-max-width-md);
  }
}
/* Media Block */
/*-----------------------------------------------------*/
.media-block > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1024px) {
  .media-block > .container {
    max-width: var(--block-container-max-width-md);
  }
}
/* Text With Media block - Layout 1 */
/*-----------------------------------------------------*/
.twm-block-1 {
  /*.set-item-txt() {
        .item-txt {

            //For headings that are contained withing the backoffice "rteMainContent" RTE.
            //TODO: MAYBE I CAN SHIFT THESE HEADER STYLES INTO .theme-wrapper CLASS?
            h3 {
                font-size: 1.4em;
            }

            @media @not-tablet-landscape {
                h2 {
                    margin-bottom: 35px;
                }
            }

            .reset-first-and-last-child-margins-y();
        }
    }*/
}
.twm-block-1 > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 1023px) {
  .twm-block-1 > .container {
    max-width: var(--block-container-max-width-sm);
  }
}
@media (min-width: 1024px) {
  .twm-block-1 > .container {
    max-width: var(--block-container-max-width-xl);
  }
}
.twm-block-1 .item .item-title {
  width: 100%;
}
@media (min-width: 1024px) {
  .twm-block-1 .item {
    display: flex;
    align-items: center;
    align-items: start;
    flex-wrap: wrap;
  }
  .twm-block-1 .item .item-title {
    width: 100%;
  }
  .twm-block-1 .item .item-txt {
    width: 1%;
    flex-grow: 1;
  }
  .twm-block-1.txt-left .item {
    flex-direction: row-reverse;
  }
  .twm-block-1.txt-left .item .item-txt {
    padding-right: 50px;
  }
  .twm-block-1.txt-right .item {
    flex-direction: row;
  }
  .twm-block-1.txt-right .item .item-txt {
    padding-left: 50px;
  }
}
@media (min-width: 1367px) {
  .twm-block-1.txt-left .item .item-txt {
    padding-right: 100px;
  }
  .twm-block-1.txt-right .item .item-txt {
    padding-left: 100px;
  }
}
.twm-block-1 .item .item-title.title-smallest h1.main {
  font-size: clamp(2.1rem, calc(1.47rem + 1.75vw), 3.5rem);
  line-height: 1.4;
}
.twm-block-1 .item .item-title.title-smaller h1.main {
  font-size: clamp(2.55rem, calc(1.785rem + 2.125vw), 4.25rem);
  line-height: 1.4;
}
.twm-block-1 .item .item-title.title-bigger h1.main {
  font-size: clamp(3.3rem, calc(2.31rem + 2.75vw), 5.5rem);
}
.twm-block-1 .item .item-title.title-biggest h1.main {
  font-size: clamp(3.6rem, calc(2.52rem + 3vw), 6rem);
}
.twm-block-1 .item .item-content.txt-big .theme-wrapper {
  font-size: 1.1em;
}
.twm-block-1 .item .item-content.txt-bigger .theme-wrapper {
  font-size: clamp(1.1em, 2.4vw, 1.2em);
}
.twm-block-1 .item .item-content.txt-biggest .theme-wrapper {
  font-size: clamp(1.2em, 2vw, 1.4em);
}
@media (min-width: 1024px) {
  .twm-block-1 .media-width-30 {
    width: 30%;
  }
  .twm-block-1 .media-width-35 {
    width: 35%;
  }
  .twm-block-1 .media-width-40 {
    width: 40%;
  }
  .twm-block-1 .media-width-45 {
    width: 45%;
  }
  .twm-block-1 .media-width-50 {
    width: 50%;
  }
  .twm-block-1 .media-width-55 {
    width: 55%;
  }
  .twm-block-1 .media-width-60 {
    width: 60%;
  }
}
@media (max-width: 1023px) {
  .twm-block-1 .item-media {
    margin-bottom: clamp(35px, 4vw, 50px);
  }
}
.twm-block-1.no-media .item {
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}
.twm-block-1.no-media .item .item-txt {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}
/* Common Card Block Styles */
/*-----------------------------------------------------*/
.cards-block .card-items .item {
  container-type: inline-size;
}
.cards-block .card-items .item .item-content {
  font-size: clamp(0.9em, 3.5cqw, 1.2em);
  padding: 4cqw;
}
.cards-block .card-items .item .item-content .item-logo {
  margin-top: clamp(10px, 4cqw, 20px);
}
.cards-block > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1024px) {
  .cards-block > .container {
    max-width: var(--block-container-max-width-xl);
  }
}
.cards-block > .container > .item-txt {
  max-width: var(--block-container-max-width-md);
  margin-bottom: clamp(25px, 6vw, 100px);
}
.cards-block > .container > .item-txt.txt-big {
  max-width: 1200px;
  margin-bottom: clamp(30px, 7vw, 110px);
}
.cards-block > .container > .item-txt.txt-big > .theme-wrapper {
  font-size: clamp(1.05em, calc(0.9em + 0.5vw), 1.2em);
}
.cards-block > .container > .item-txt.txt-bigger {
  max-width: 1400px;
  margin-bottom: clamp(35px, 7vw, 120px);
}
.cards-block > .container > .item-txt.txt-bigger > .theme-wrapper {
  font-size: clamp(1.1em, calc(0.95em + 0.5vw), 1.4em);
}
.cards-block > .container > .item-txt.txt-biggest {
  max-width: 1600px;
  margin-bottom: clamp(50px, 7vw, 135px);
}
.cards-block > .container > .item-txt.txt-biggest > .theme-wrapper {
  font-size: clamp(1.15em, calc(1em + 0.65vw), 1.6em);
}
.cards-block > .container > .btn-items {
  margin-top: clamp(25px, 6vw, 100px);
}
/* Cards Block 1 */
/*-----------------------------------------------------*/
.cards-block-1 .card-items .item-txt > *,
.cards-block-1 .card-items .txt-wrapper > * {
  margin-bottom: clamp(10px, 2vw, 25px);
}
.cards-block-1 .card-items .item-txt > *:first-child,
.cards-block-1 .card-items .txt-wrapper > *:first-child {
  margin-top: 0;
}
.cards-block-1 .card-items .item-txt > *:last-child,
.cards-block-1 .card-items .txt-wrapper > *:last-child {
  margin-bottom: 0;
}
.cards-block-1 .card-items .btn-items {
  margin-top: 10px;
}
.cards-block-1 .card-items .title {
  font-size: 1.8em;
  font-weight: 600;
}
.cards-block-1 .card-items.txt-bigger .title {
  font-size: clamp(2em, calc(0.99em + 1.375vw), 2.31em);
}
.cards-block-1 .card-items.txt-biggest .title {
  font-size: clamp(2em, calc(1.08em + 1.5vw), 2.52em);
}
.cards-block-1 .card-items .title,
.cards-block-1 .card-items .theme-wrapper {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cards-block-1 .card-items .title {
  -webkit-line-clamp: 3;
}
.cards-block-1 .card-items .theme-wrapper {
  -webkit-line-clamp: 5;
}
.cards-block-1 .card-items .item {
  display: flex;
  flex-direction: column;
}
.cards-block-1 .card-items .item .item-txt {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.cards-block-1 .card-items .item .item-txt .txt-wrapper {
  flex-grow: 1;
}
@media (hover: none) {
  .cards-block-1 .card-items > a.item .item-media {
    position: relative;
  }
  .cards-block-1 .card-items > a.item .item-media:after {
    position: absolute;
    right: 0;
    bottom: 0;
    font-family: 'IcoFont';
    content: '\ea5d';
    font-size: 2.25em;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1;
  }
}
.cards-block-1 .card-items .item .item-media {
  border-radius: 5px;
  overflow: hidden;
}
.cards-block-1 .card-items .item .item-txt {
  padding: 0;
  padding-top: 1em;
}
.cards-block-1 .card-items .item .item-txt .txt-wrapper {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}
.cards-block-1 .card-items .item .item-txt .txt-wrapper .title {
  font-size: clamp(1.8em, 2.5vw, 2.25em);
  font-weight: 300;
  margin: 0;
}
.cards-block-1 .card-items .item .item-txt .txt-wrapper .supplement {
  font-family: "Montserrat", sans-serif;
  font-size: 1.25em;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.05em;
  margin: 0;
}
.cards-block-1 .card-items .item .item-txt .txt-wrapper .theme-wrapper {
  margin-top: 0.5em;
}
/* Cards Block 2 */
/*-----------------------------------------------------*/
.cards-block-2 .card-items .txt-wrapper > * {
  margin-bottom: clamp(10px, 2vw, 25px);
}
.cards-block-2 .card-items .txt-wrapper > *:first-child {
  margin-top: 0;
}
.cards-block-2 .card-items .txt-wrapper > *:last-child {
  margin-bottom: 0;
}
.cards-block-2 .card-items .title {
  font-size: clamp(1.85rem, 9.68cqw - 5.26px, 3rem);
  font-weight: 300;
}
.cards-block-2 .card-items .title,
.cards-block-2 .card-items .theme-wrapper {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cards-block-2 .card-items .title {
  -webkit-line-clamp: 2;
}
.cards-block-2 .card-items .theme-wrapper {
  -webkit-line-clamp: 5;
}
.cards-block-2 .card-items .item {
  position: relative;
  display: block;
  border-radius: var(--img-border-radius);
  overflow: hidden;
}
.cards-block-2 .card-items .item .item-txt {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.35);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.1) 40%, rgba(0, 0, 0, 0.4) 80%, rgba(0, 0, 0, 0.7) 100%);
  color: var(--font-color-light);
  padding: 15px 25px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
}
/* Call To Action Block - Layout 1 */
/*-----------------------------------------------------*/
.cta-block-1 {
  position: relative;
  z-index: 0;
  background-size: cover;
  background-position: center center;
  background-attachment: scroll;
  height: 100svh;
  max-height: clamp(600px, 428.57px + 47.62vw, 1000px);
  min-height: 450px;
  display: flex;
  align-items: center;
}
.cta-block-1 > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1024px) {
  .cta-block-1 > .container {
    max-width: var(--block-container-max-width-md);
    max-width: 1200px;
  }
}
.cta-block-1 .item-txt {
  text-align: center;
}
.cta-block-1 .item-txt .title-1 {
  margin-bottom: clamp(75px, 8vw, 100px);
}
.cta-block-1 .item-txt .title-1 h1 {
  font-size: clamp(2.25em, calc(1.53em + 2.125vw), 3.57em);
  line-height: 1.4;
  text-shadow: 0 0 15px #000;
}
.cta-block-1 .item-txt .theme-wrapper {
  font-size: clamp(1em, 1.6vw, 1.4em);
  text-shadow: 0 0 15px #000;
}
@media (max-width: 599px) {
  .cta-block-1 .btn-items {
    font-size: clamp(1em, 5.4vw, 1.35em);
  }
}
@media (min-width: 600px) {
  .cta-block-1 .btn-items {
    font-size: clamp(1.35em, 3vw, 1.5em);
  }
}
@media (max-width: 767px) {
  .cta-block-1 .btn-items > .flex-container {
    flex-direction: column;
  }
}
@media (min-width: 768px) {
  .cta-block-1 .btn-items .btn:first-child {
    min-width: 50%;
  }
  .cta-block-1 .btn-items .btn:last-child {
    flex-grow: 1;
  }
}
@media (pointer: fine) {
  @supports not (-webkit-touch-callout: none) {
    .cta-block-1 {
      background-attachment: fixed;
    }
  }
}
.cta-block-1::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background-color: #000;
  opacity: 0.5;
}
/* Form Block */
/*-----------------------------------------------------*/
.form-block > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1024px) {
  .form-block > .container {
    max-width: var(--block-container-max-width-md);
  }
}
.form-block .item > .item-txt {
  margin-bottom: clamp(25px, 4vw, 50px);
}
.form-aside-block > .container {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1024px) {
  .form-aside-block > .container {
    max-width: 1400px;
  }
}
@media (max-width: 1023px) {
  .form-aside-block .container > .item > * {
    margin-bottom: 50px;
  }
  .form-aside-block .container > .item > *:last-child {
    margin-bottom: 0;
  }
}
@media (min-width: 1024px) {
  .form-aside-block .container > .item {
    display: grid;
    row-gap: 100px;
    column-gap: 50px;
    grid-template-columns: 7fr 3fr;
  }
  .form-aside-block .container > .item > .item-txt {
    grid-column: 1 / -1;
  }
}
.form-aside-block aside .contact-items > .item {
  text-align: center;
  margin-bottom: clamp(25px, 4vw, 60px);
}
@media (max-width: 1023px) {
  .form-aside-block aside .contact-items > .item:last-child {
    margin-bottom: 0;
  }
}
.form-aside-block aside .contact-items > .item .content {
  line-height: 1.4;
}
.form-aside-block aside .contact-items > .item .content .label {
  font-family: 'Urbanist', sans-serif;
  font-weight: 200;
  margin-bottom: 15px;
}
.form-aside-block aside .contact-items > .item .content a:not(.img-link) {
  display: inline-block;
  color: var(--link-color);
  background-color: var(--link-bg-color);
  border-bottom: 1px dotted var(--link-border-color);
  transition: all 0.15s ease;
}
.form-aside-block aside .contact-items > .item .content a:not(.img-link):hover {
  color: var(--link-color-hover);
  background-color: var(--link-bg-color-hover);
  border-bottom: 1px solid var(--link-border-color-hover);
}
.form-aside-block aside .item .content > a.img-link {
  display: inline-block;
  position: relative;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  margin-right: 10px;
}
.form-aside-block aside .item .content > a.img-link:last-child {
  margin-right: 0;
}
.form-aside-block aside .item .content > a.img-link .semps-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  font-size: 1.5em;
  line-height: inherit;
}
/* Media Gallery Block */
/*-----------------------------------------------------*/
.gallery-block > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 1023px) {
  .gallery-block > .container {
    max-width: var(--block-container-max-width-sm);
  }
}
@media (min-width: 1024px) {
  .gallery-block > .container {
    max-width: var(--block-container-max-width-xl);
  }
}
.gallery-block .gallery-items .item {
  border-radius: 5px;
  overflow: hidden;
}
.gallery-block.tiled .gallery-items {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.gallery-block.tiled .gallery-items .item {
  width: 50%;
}
@media (min-width: 1024px) {
  .gallery-block.tiled .gallery-items .item {
    width: 25%;
  }
}
@media (max-width: 1023px) {
  .gallery-block.tiled .gallery-items.alt-1 {
    margin: -7.5px;
  }
  .gallery-block.tiled .gallery-items.alt-1 .item {
    width: calc(33.33% - (7.5px * 2));
    margin: 7.5px;
  }
}
@media (min-width: 1024px) {
  .gallery-block.tiled .gallery-items.alt-1 {
    margin: -10px;
  }
  .gallery-block.tiled .gallery-items.alt-1 .item {
    width: calc(25% - (10px * 2));
    margin: 10px;
  }
}
@media (min-width: 1367px) {
  .gallery-block.tiled .gallery-items.alt-1 {
    margin: -12.5px;
  }
  .gallery-block.tiled .gallery-items.alt-1 .item {
    width: calc(25% - (12.5px * 2));
    margin: 12.5px;
  }
}
.gallery-block.tiled .gallery-items .item .item-img {
  display: block;
  position: relative;
  padding-top: 100%;
}
.gallery-block.tiled .gallery-items .item .item-img img {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
}
.gallery-block.tiled .gallery-items .item .item-img .text-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  z-index: 1;
  font-size: 0.9em;
  color: #fff;
  background-color: #222;
  text-align: center;
  opacity: 0;
  transition: opacity 0.2s ease;
}
@media (max-width: 479px) {
  .gallery-block.tiled .gallery-items .item .item-img .text-overlay {
    font-size: 0.75em;
  }
}
.gallery-block.tiled .gallery-items .item .item-img .text-overlay:hover {
  opacity: 0.8;
}
.gallery-block.tiled .gallery-items .item .item-img .text-overlay .icofont {
  font-size: 2em;
}
.gallery-block.tiled .gallery-items .item .item-img img {
  object-fit: cover;
}
.gallery-block.masonry .gallery-items {
  column-count: 3;
  column-gap: 20px;
}
@media (max-width: 1023px) {
  .gallery-block.masonry .gallery-items {
    column-count: 2;
  }
}
.gallery-block.masonry .gallery-items .item {
  break-inside: avoid;
  margin-bottom: 20px;
}
.gallery-block.masonry .gallery-items .item img {
  width: 100%;
  height: auto;
  border-radius: 6px;
  display: block;
}
.gallery-block.quilted .gallery-items {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(0.25rem, -0.0714rem + 1.4286vw, 1rem);
}
.gallery-block.quilted .gallery-items .item.reg {
  grid-column: span 2;
}
.gallery-block.quilted .gallery-items .item.reg img {
  aspect-ratio: 3 / 2;
}
.gallery-block.quilted .gallery-items .item.tall {
  grid-column: span 2;
  grid-row: span 2;
}
.gallery-block.quilted .gallery-items .item.tall img {
  aspect-ratio: 3 / 4;
}
.gallery-block.quilted .gallery-items .item.big {
  grid-column: span 4;
  grid-row: span 2;
}
.gallery-block.quilted .gallery-items .item.big img {
  aspect-ratio: 3 / 2;
}
.gallery-block.quilted .gallery-items .item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Video Block */
/*-----------------------------------------------------*/
.video-block {
  position: relative;
  flex-grow: 1;
}
.video-block .video-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  visibility: hidden;
  opacity: 0;
}
.video-block .video-wrapper.show {
  visibility: visible;
  opacity: 1;
  transition: opacity 1.5s ease;
}
.video-block .video-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.video-block .video-wrapper video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Hero Block */
/*-----------------------------------------------------*/
.hero-block {
  position: relative;
  height: 100svh;
  max-height: clamp(600px, 428.57px + 47.62vw, 1000px);
  min-height: 450px;
}
.hero-block img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  /* Can be overridden using the Umbraco "Focal Point" feature */
}
.hero-block > video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: bottom;
}
.hero-block::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.35);
}
.hero-block .item-txt {
  position: absolute;
  z-index: 1;
  left: 0;
  bottom: 0;
  margin: clamp(15px, 4vw, 50px);
  max-width: 1000px;
}
.hero-block .item-txt .item-title {
  display: flex;
  flex-direction: column;
  border-bottom: 4px solid var(--color-accent-1);
  margin-bottom: 25px;
}
.hero-block .item-txt .item-title .main {
  font-weight: 300;
  color: #fff;
  text-transform: uppercase;
  line-height: 1.1;
  margin: 0;
}
.hero-block .item-txt .item-title .supplement {
  font-size: clamp(1.4em, 2.5vw, 1.8em);
  font-weight: 400;
  letter-spacing: 0.05em;
  color: #fff;
  text-transform: uppercase;
  margin: 0;
  margin-bottom: 5px;
}
.hero-block .item-txt .item-content {
  color: #fff;
  text-align: justify;
  text-align: left;
  margin: 0;
  padding: 0;
}
.hero-block .item-txt .item-content .theme-wrapper {
  margin: 0;
}
#home-hero.hero-block .item-txt .item-title .main {
  letter-spacing: 0.1em;
  line-height: 1.2;
}
#home-hero.hero-block .item-txt .item-title .supplement {
  letter-spacing: 0.28em;
  margin-bottom: 0;
}
