/*=====================================================*/
/*===========        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: #222;
  --color-secondary: #ececec;
  --color-accent-1: #0972ce;
  --color-accent-2: #ee433d;
  --color-accent-1-darker: #064985;
  --color-accent-2-darker: #e41b14;
  --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-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);
  --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);
}
:root {
  --body-container-max-width: 2000px;
  --content-container-max-width: 1400px;
  --block-container-max-width-sm: 800px;
  --block-container-max-width-md: 1000px;
  --block-container-max-width-xl: 1500px;
  --block-spacing-sm: 25px;
  --block-spacing-md: 50px;
  --block-spacing-lg: 100px;
  --block-spacing-xl: 150px;
  --item-spacing: clamp(25px, 4vw, 50px);
}
/*.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 */
/*-----------------------------------------------------*/
body {
  font-family: 'Abhaya Libre', serif;
  font-weight: 400;
  color: var(--font-color);
  line-height: 1.7;
  font-size: clamp(18px, calc(16px + 0.3vw), 20px);
}
@media (max-width: 767px) {
  body {
    line-height: 1.6;
  }
}
body.smaller-font {
  font-size: clamp(17px, calc(15px + 0.3vw), 19px);
}
body.bigger-font {
  font-size: clamp(19px, calc(17px + 0.3vw), 21px);
}
body.biggest-font {
  font-size: clamp(20px, calc(18px + 0.3vw), 22px);
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Abhaya Libre', serif;
  font-weight: 500;
  color: var(--heading-color);
  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(2.5em, calc(1.8em + 2.5vw), 4.2em);
}
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);
}
/* 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-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: 'Abhaya Libre', serif;
  font-weight: 600;
  text-align: center;
  line-height: inherit;
  text-decoration: none;
  border-radius: 0;
  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: 2px 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-accent-2);
  --btn-color: var(--font-color-light);
  --btn-border-color: var(--color-accent-2);
  --btn-bg-color-hover: transparent;
  --btn-border-color-hover: var(--color-accent-2);
}
.btn-clr.btn-clr-2-inverse {
  --btn-bg-color: transparent;
  --btn-border-color: var(--color-accent-2);
  --btn-bg-color-hover: var(--color-accent-2);
  --btn-color-hover: var(--font-color-light);
  --btn-border-color-hover: var(--color-accent-2);
}
.btn-clr.btn-clr-3 {
  --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-3-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-clr.btn-clr-4 {
  --btn-bg-color: var(--color-secondary);
  --btn-color: var(--font-color-dark);
  --btn-border-color: var(--color-secondary);
  --btn-bg-color-hover: transparent;
  --btn-border-color-hover: var(--color-secondary);
}
.btn-clr.btn-clr-4-inverse {
  --btn-bg-color: transparent;
  --btn-border-color: var(--color-secondary);
  --btn-bg-color-hover: var(--color-secondary);
  --btn-color-hover: var(--font-color-dark);
  --btn-border-color-hover: var(--color-secondary);
}
.btn-clr.btn-clr-5 {
  --btn-bg-color: var(--surface-color-light);
  --btn-color: var(--font-color-dark);
  --btn-border-color: var(--surface-color-light);
  --btn-bg-color-hover: transparent;
  --btn-border-color-hover: var(--surface-color-light);
}
.btn-clr.btn-clr-5-inverse {
  --btn-bg-color: transparent;
  --btn-border-color: var(--surface-color-light);
  --btn-bg-color-hover: var(--surface-color-light);
  --btn-color-hover: var(--font-color-dark);
  --btn-border-color-hover: var(--surface-color-light);
}
/* Link style buttons  */
/*-----------------------------------------------------*/
.btn.btn-lnk {
  font-weight: normal;
}
.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-accent-2);
  --link-border-color-hover: var(--color-accent-2);
}
.btn.lnk-clr.lnk-clr-3 {
  --link-border-color: var(--color-primary);
  --link-border-color-hover: var(--color-primary);
}
.btn.lnk-clr.lnk-clr-4 {
  --link-border-color: var(--color-secondary);
  --link-border-color-hover: var(--color-secondary);
}
.btn.lnk-clr.lnk-clr-5 {
  --link-border-color: var(--surface-color-light);
  --link-border-color-hover: var(--surface-color-light);
}
/* Backoffice RTE's  */
/*-----------------------------------------------------*/
.theme-wrapper {
  margin-bottom: clamp(25px, 4vw, 50px);
}
.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);
}
.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: 'Abhaya Libre', serif;
  font-weight: 400;
  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: 'Abhaya Libre', 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: 'Abhaya Libre', serif;
  font-weight: 400;
  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;
  row-gap: var(--grid-item-spacing);
  column-gap: var(--grid-item-spacing);
}
@media (max-width: 1023px) {
  .grid-items {
    --grid-item-spacing: clamp(25px, 6vw, 35px);
    grid-template-columns: 1fr;
  }
}
@media (min-width: 1024px) {
  .grid-items.cols-2,
  .grid-items.cols-4 {
    --grid-item-spacing: clamp(25px, 2.5vw, 50px);
    grid-template-columns: 1fr 1fr;
  }
  .grid-items.cols-3 {
    --grid-item-spacing: 25px;
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media (min-width: 1367px) {
  .grid-items.cols-4 {
    --grid-item-spacing: 25px;
    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-primary);
}
.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-primary);
}
.hover-txt-2 {
  background-image: linear-gradient(var(--color-primary), var(--color-primary));
  background-size: 0% 3px;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  transition: background-size 0.5s;
}
.hover-txt-2:hover {
  background-size: 100% 3px;
}
.hover-txt-child-2 .title span {
  background-image: linear-gradient(var(--color-primary), var(--color-primary));
  background-size: 0% 3px;
  background-position: 0% 100%;
  background-repeat: no-repeat;
  transition: background-size 0.5s;
}
.hover-txt-child-2:hover .title span {
  background-size: 100% 3px;
}
.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;
}
@media (min-width: 1600px) {
  .txt-bigger > .item-title,
  .txt-bigger > .theme-wrapper {
    font-size: 1.1em;
  }
  .txt-bigger > .container > .item > .item-title,
  .txt-bigger > .container > .item > .item-txt > .theme-wrapper {
    font-size: 1.1em;
  }
  .txt-bigger > .container > .item > .item-txt > .item-title,
  .txt-bigger > .container > .item > .item-txt > .item-content > .theme-wrapper {
    font-size: 1.1em;
  }
  .txt-biggest > .item-title,
  .txt-biggest > .theme-wrapper {
    font-size: 1.2em;
  }
  .txt-biggest > .container > .item > .item-title,
  .txt-biggest > .container > .item > .item-txt > .theme-wrapper {
    font-size: 1.2em;
  }
  .txt-biggest > .container > .item > .item-txt > .item-title,
  .txt-biggest > .container > .item > .item-txt > .item-content > .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: 2px solid var(--border-color);
  width: 35%;
  margin: clamp(25px, 4vw, 50px) auto;
}
/* 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;
}
/* For scroll to "top of page" */
/*-----------------------------------------------------*/
#to-top {
  position: fixed;
  bottom: 10px;
  right: 10px;
  z-index: 100;
  visibility: hidden;
  opacity: 0;
  border-radius: 50%;
  padding: 24px;
  cursor: pointer;
  transition: all 0.15s ease;
}
#to-top::before {
  font-family: 'IcoFont';
  content: '\ea5e';
  font-size: 1.75em;
  line-height: 1;
  color: inherit;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}
#to-top.show {
  visibility: visible;
  opacity: 1;
}
#to-top:hover {
  background: #fff;
}
/* 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;
}
/* 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: 1024px) {
  #header {
    padding: 0 clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-md));
  }
}
#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;
}
#header .header-row .logo-wrapper a img {
  width: clamp(80px, 10vw, 140px);
}
@media (max-width: 1023px) {
  #header .header-row .logo-wrapper {
    padding: 10px;
  }
}
@media (min-width: 1024px) {
  #header .header-row .logo-wrapper {
    margin-top: -45px;
    margin-bottom: 15px;
  }
}
#header .header-row .logo-wrapper.has-text {
  display: flex;
  flex-direction: row;
}
#header .header-row .logo-wrapper.has-text h1 {
  font-size: clamp(1.6em, calc(1.2em + 1.8vw), 2.5em);
  font-weight: 400;
  line-height: 1;
}
@media (max-width: 1023px) {
  #header .header-row .logo-wrapper.has-text {
    align-items: center;
    max-width: calc(100% - 70px);
  }
  #header .header-row .logo-wrapper.has-text h1 {
    margin: 0 0 0 10px;
  }
}
@media (min-width: 1024px) {
  #header .header-row .logo-wrapper.has-text {
    align-items: flex-end;
    margin-bottom: 10px;
  }
  #header .header-row .logo-wrapper.has-text h1 {
    margin: 0;
  }
}
#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: 'Abhaya Libre', serif;
  font-weight: 500;
  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;
    margin-right: -20px;
  }
}
@media (min-width: 1367px) {
  .nav-wrapper {
    margin-right: -25px;
  }
}
/* Main Navigation */
/*-----------------------------------------------------*/
nav.main ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
nav.main a {
  display: block;
  font-weight: 500;
  font-size: 1.05em;
  line-height: 1.2;
}
@media (min-width: 1024px) {
  nav.main a {
    font-size: 1.05em;
  }
}
nav.main ul.nav-submenu {
  background-color: var(--nav-submenu-bg-color);
}
nav.main a {
  color: var(--nav-item-color);
  background-color: var(--nav-item-bg-color);
}
nav.main a:hover {
  color: var(--nav-item-color-hover);
  background-color: var(--nav-item-bg-color-hover);
}
@media (max-width: 1023px) {
  nav.main {
    position: absolute;
    width: 100%;
    z-index: 102;
    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;
  }
  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);
  }
}
/* Main Navigation Open/Close Toggle */
/*-----------------------------------------------------*/
.nav-toggle-wrapper {
  width: 70px;
}
@media (min-width: 1024px) {
  .nav-toggle-wrapper {
    display: none;
  }
}
.nav-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  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: 25px;
  height: 2px;
  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: -8px;
}
.nav-toggle .nav-hamburger:after {
  bottom: -8px;
}
.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 */
/*-----------------------------------------------------*/
@media (min-width: 1024px) {
  footer.block {
    padding-bottom: 50px !important;
  }
}
footer > .container {
  max-width: var(--content-container-max-width);
  margin: 0 auto;
}
footer .grid-items {
  display: grid;
  row-gap: 15px;
  column-gap: 15px;
}
@media (max-width: 1023px) {
  footer .grid-items {
    grid-template-columns: 1fr;
    justify-items: center;
    row-gap: 35px;
  }
  footer .grid-items .item {
    text-align: center;
  }
}
@media (min-width: 1024px) {
  footer .grid-items {
    grid-template-columns: 1fr 1fr 1fr;
  }
  footer .grid-items .item.item-2 {
    align-self: center;
    justify-self: center;
  }
  footer .grid-items .item.item-3 {
    text-align: right;
  }
  footer .grid-items .item.item-4 {
    grid-column: 1 / span 3;
  }
}
footer .grid-items > .item > *:first-child {
  margin-top: 0;
}
footer .grid-items > .item > *:last-child {
  margin-bottom: 0;
}
footer section {
  margin: clamp(25px, 4vw, 50px) 0;
}
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(180px, 18vw, 200px);
}
footer .business-logo a {
  display: block;
}
/* Footer Page Links */
/*-----------------------------------------------------*/
footer .page-links ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
footer .page-links ul li {
  margin-bottom: 10px;
}
footer .page-links ul li:last-child {
  margin-bottom: 0;
}
/* Footer Contact Details */
/*-----------------------------------------------------*/
footer .contact-details > .items {
  display: grid;
  grid-template-columns: auto;
  row-gap: 5px;
}
/* Footer Social Icons */
/*-----------------------------------------------------*/
footer .social-media-links {
  display: flex;
}
@media (max-width: 1023px) {
  footer .social-media-links {
    justify-content: center;
  }
}
@media (min-width: 1024px) {
  footer .social-media-links {
    justify-content: flex-end;
  }
}
footer .social-media-links > div {
  margin: 0 5px;
}
footer .social-media-links > div > a {
  display: inline-flex;
  border-radius: 50%;
  transition: all 0.15s ease;
}
footer .social-media-links > div > a .semps-icon {
  font-size: 30px;
  padding: 10px;
}
footer .social-media-links > *:first-child {
  margin-left: 0;
}
footer .social-media-links > *:last-child {
  margin-right: 0;
}
/* 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, 75px);
}
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.85em;
}
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 {
  margin-bottom: clamp(25px, 4vw, 50px);
}
.block .title-1 .supplement {
  display: inline-block;
  font-weight: 600;
  margin-bottom: 10px;
}
.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-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);
}
.block-clr-1,
.item-clr-1 {
  --bg-color: var(--color-primary);
  --font-color: var(--font-color-light);
  --heading-color: var(--font-color-light);
  --title-color: var(--font-color-light);
  --title-bg-color: transparent;
  --supplement-color: var(--font-color-light);
  --supplement-bg-color: transparent;
  --link-bg-color: transparent;
  --link-color: var(--font-color-light);
  --link-border-color: var(--color-accent-1);
  --link-bg-color-hover: transparent;
  --link-color-hover: var(--font-color-light);
  --link-border-color-hover: var(--color-accent-1);
  --list-style-color: var(--surface-color-light);
}
.block-clr-2,
.item-clr-2 {
  --bg-color: var(--color-secondary);
  --font-color: var(--font-color-dark);
  --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(--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);
}
.block-clr-3,
.item-clr-3 {
  --bg-color: var(--color-accent-1);
  --font-color: var(--font-color-light);
  --heading-color: var(--font-color-light);
  --title-color: var(--font-color-light);
  --title-bg-color: transparent;
  --supplement-color: var(--font-color-light);
  --supplement-bg-color: transparent;
  --link-bg-color: transparent;
  --link-color: var(--font-color-light);
  --link-border-color: var(--font-color-light);
  --link-bg-color-hover: transparent;
  --link-color-hover: var(--font-color-light);
  --link-border-color-hover: var(--font-color-light);
  --list-style-color: var(--surface-color-light);
}
.block-clr-4,
.item-clr-4 {
  --bg-color: var(--surface-color-light);
  --font-color: var(--font-color-dark);
  --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(--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);
}
.block-clr-1 .btn-clr-1,
.block .item-clr-1 .btn-clr-1,
.block-clr-3 .btn-clr-1,
.block .item-clr-3 .btn-clr-1,
.block-clr-1 .btn-clr-2,
.block .item-clr-1 .btn-clr-2,
.block-clr-3 .btn-clr-2,
.block .item-clr-3 .btn-clr-2,
.block-clr-1 .btn-clr-3,
.block .item-clr-1 .btn-clr-3,
.block-clr-3 .btn-clr-3,
.block .item-clr-3 .btn-clr-3,
.block-clr-1 .btn-clr-4,
.block .item-clr-1 .btn-clr-4,
.block-clr-3 .btn-clr-4,
.block .item-clr-3 .btn-clr-4,
.block-clr-1 .btn-clr-5,
.block .item-clr-1 .btn-clr-5,
.block-clr-3 .btn-clr-5,
.block .item-clr-3 .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-4 .btn-clr-1,
.block .item-clr-4 .btn-clr-1,
.block-clr-2 .btn-clr-2,
.block .item-clr-2 .btn-clr-2,
.block-clr-4 .btn-clr-2,
.block .item-clr-4 .btn-clr-2,
.block-clr-2 .btn-clr-3,
.block .item-clr-2 .btn-clr-3,
.block-clr-4 .btn-clr-3,
.block .item-clr-4 .btn-clr-3,
.block-clr-2 .btn-clr-4,
.block .item-clr-2 .btn-clr-4,
.block-clr-4 .btn-clr-4,
.block .item-clr-4 .btn-clr-4,
.block-clr-2 .btn-clr-5,
.block .item-clr-2 .btn-clr-5,
.block-clr-4 .btn-clr-5,
.block .item-clr-4 .btn-clr-5 {
  --btn-color-hover: var(--font-color-dark);
}
.block-clr-1 {
  --nav-submenu-bg-color: var(--color-primary);
  --nav-item-bg-color: var(--color-primary);
  --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 .item-clr,
.form-block .item-clr {
  padding: clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-lg));
}
/* Page Title block - Layout 1 */
/*-----------------------------------------------------*/
.page-title-block-1 > .title {
  font-size: clamp(2.5em, calc(1.5em + 3.5vw), 4.2em);
}
/* Page Title block - Layout 2 */
/*-----------------------------------------------------*/
.page-title-block-2 {
  margin: 0;
  background-color: #000;
  padding: clamp(75px, 10vw, 180px) 25px;
  background-size: cover;
  background-position: center center;
  position: relative;
  z-index: 0;
}
.page-title-block-2 > .title {
  font-size: clamp(2.5em, calc(1.5em + 3.5vw), 4.2em);
  color: #fff;
  margin: 0 auto;
}
.page-title-block-2::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background-color: #000;
  opacity: 0.5;
}
.page-title-block-2.img-fixed {
  background-attachment: fixed;
}
/* Page Title block - Layout 3 */
/*-----------------------------------------------------*/
.page-title-block-3 {
  background: #222;
  margin: 0;
  padding: clamp(var(--block-spacing-sm), 8vw, var(--block-spacing-md));
  padding: clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-md));
  background-image: url('/_assets/images/backgrounds/patterns/svg/47.svg');
  background-size: auto;
  background-position: top left;
}
.page-title-block-3 > .title {
  color: transparent;
  -webkit-text-stroke: 2px tomato;
  margin: 0;
  text-align: left;
  font-weight: 900;
  font-family: 'Geologica', sans-serif;
}
@media (min-width: 1367px) {
  .page-title-block-3 > .title {
    font-size: 6em;
  }
}
/* Page Title block - Layout 4 */
/*-----------------------------------------------------*/
.page-title-block-4 {
  /*background: #f5f5f5;*/
  margin: 0;
  padding: clamp(var(--block-spacing-md), 8vw, var(--block-spacing-lg)) clamp(var(--block-spacing-sm), 6vw, var(--block-spacing-lg));
}
.page-title-block-4 > .title {
  color: transparent;
  -webkit-text-stroke: 2px tomato;
  border-bottom: 2px solid tomato;
  margin: 0;
  text-align: left;
  font-weight: 900;
  font-family: 'Geologica', sans-serif;
  /*color: #fff;*/
  /*text-shadow: 0px 4px 4px #282828;*/
  /*text-shadow: 4px 4px 6px #4d4d4d5c;*/
  /*text-shadow: 5px -5px 0px tomato;*/
  /*-webkit-text-stroke: 2px #222;*/
}
@media (min-width: 1367px) {
  .page-title-block-4 > .title {
    font-size: 6em;
  }
}
/* Text Block */
/*-----------------------------------------------------*/
.txt-block > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1024px) {
  .txt-block > .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);
  }
}
/* Media Block v2 */
/*-----------------------------------------------------*/
.media-block-v2 {
  margin: 0;
}
.media-block-v2 .item-bg-img {
  background-size: cover;
  height: clamp(180px, 35vw, 600px);
}
.media-block-v2 .item-bg-img.img-fixed {
  background-attachment: fixed;
}
/* 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);
  }
}
@media (min-width: 1024px) {
  .twm-block-1 .item {
    display: flex;
    align-items: center;
    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;
  }
}
@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(25px, 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;
}
/* Text With Media block - Layout 2 */
/*-----------------------------------------------------*/
@media (min-width: 1024px) {
  .block.twm-block-2 {
    padding: 0;
    margin: 0;
  }
}
.twm-block-2 {
  /*.set-item-media-is-photo() {
        &.contain-photo .item {
            @media @tablet-landscape {
                background-color: @bg-color-neutral-lighter;
            }
        }
    }*/
  /*.set-item-media-is-video() {

        &.is-video .item {
            background-color: @bg-color-neutral-lighter;

            @media @tablet-landscape {
                .item-media {
                    width: 50%;
                    //padding-right: 65px; //depends on alignment
                }

                .item-txt {
                    position: relative;
                    width: 50%;
                }
            }
        }
    }*/
}
.twm-block-2 > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 1023px) {
  .twm-block-2 > .container {
    max-width: var(--block-container-max-width-sm);
  }
}
@media (min-width: 1024px) {
  .twm-block-2 .item {
    display: flex;
  }
  .twm-block-2 .item .item-txt {
    width: 1%;
    flex-grow: 1;
    align-self: center;
  }
  .twm-block-2.txt-left .item {
    flex-direction: row-reverse;
  }
  .twm-block-2.txt-right .item {
    flex-direction: row;
  }
}
.twm-block-2 .item-txt {
  /*.item-title {

                @media @not-tablet-landscape {
                    margin-bottom: clamp(15px, 4vw, 25px);

                    > .main {
                        font-size: clamp(2.5em, 7vw, 3em); // min: ~500px --> max: ~600px
                    }
                }

                @media @tablet-landscape {
                    margin-bottom: clamp(25px, 4vw, 50px);

                    > .main {
                        //font-size: 4.5em;
                        font-size: clamp(2.5em, calc(1.23em + 2.5vw), 4.5em);
                    }
                }

                .reset-first-and-last-child-margins-y(); //Override default h1, h2, h3, etc. margins
            }*/
  /*.item-title, .theme-wrapper {
                h1, h2 {
                    @media @not-tablet-portrait {
                        margin-bottom: 35px;
                    }
                }

                h3 {
                    color: @font-color-primary-1;
                }
            }*/
}
@media (min-width: 1024px) {
  .twm-block-2 .item-txt {
    padding: clamp(50px, 5vw, 100px);
  }
}
@media (min-width: 1024px) {
  .twm-block-2 .media-width-30 {
    width: 30%;
  }
  .twm-block-2 .media-width-35 {
    width: 35%;
  }
  .twm-block-2 .media-width-40 {
    width: 40%;
  }
  .twm-block-2 .media-width-45 {
    width: 45%;
  }
  .twm-block-2 .media-width-50 {
    width: 50%;
  }
  .twm-block-2 .media-width-55 {
    width: 55%;
  }
  .twm-block-2 .media-width-60 {
    width: 60%;
  }
}
@media (max-width: 1023px) {
  .twm-block-2 .item-media {
    margin-bottom: clamp(25px, 4vw, 50px);
  }
}
@media (min-width: 1024px) {
  .twm-block-2 .item-media .item-img {
    height: 100%;
  }
}
.twm-block-2.no-media .item {
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}
.twm-block-2.no-media .item .item-txt {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}
/* Common Card Block Styles */
/*-----------------------------------------------------*/
.cards-block > .container {
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 1023px) {
  .cards-block > .container {
    max-width: var(--block-container-max-width-sm);
  }
}
@media (min-width: 1024px) {
  .cards-block > .container {
    max-width: var(--block-container-max-width-xl);
  }
}
.cards-block > .container > .item-txt {
  margin-bottom: clamp(25px, 6vw, 100px);
}
@media (min-width: 1024px) {
  .cards-block > .container > .item-txt {
    max-width: var(--block-container-max-width-md);
  }
}
.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;
}
/* 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: 1.5em;
  font-weight: 600;
}
.cards-block-2 .card-items.txt-bigger .title {
  font-size: clamp(2em, calc(0.99em + 1.375vw), 2.31em);
}
.cards-block-2 .card-items.txt-biggest .title {
  font-size: clamp(2em, calc(1.08em + 1.5vw), 2.52em);
}
.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;
}
.cards-block-2 .card-items .item .item-txt {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  background-color: var(--color-primary);
  color: var(--font-color-light);
  padding: 15px 25px;
}
.cards-block-2 .card-items.use-icons .item .item-img {
  width: min(50%, 200px);
  margin-left: auto;
  margin-right: auto;
}
/* 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: 'Abhaya Libre', serif;
  font-weight: 400;
  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;
}
/* Main / Aside - Two column layout */
/*-----------------------------------------------------*/
.contact-block .contact-items-container {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 1024px) {
  .contact-block .contact-items-container {
    max-width: 1400px;
  }
}
.contact-block .contact-items {
  /*.set-contact-icons() {
                .contact-variants .item > .icofont {
                    font-size: 3em;
                    color: @font-color-primary-2;
                    margin-right: @item-margin-lg;

                    @media @not-desktop {
                        display: none;
                    }
                }
            }*/
  /*.set-contact-image() {
                .img-wrapper {
                    .set-img-aspect-ratio(@ratio-4-3-as-a-percentage);
                    .set-img-fit();
                }
            }*/
}
@media (max-width: 1023px) {
  .contact-block .contact-items .main {
    margin-bottom: 50px;
  }
}
@media (min-width: 1024px) {
  .contact-block .contact-items {
    display: flex;
    flex-direction: row;
    margin: -25px;
  }
  .contact-block .contact-items .main {
    width: calc(70% - 50px);
    margin: 25px;
  }
  .contact-block .contact-items aside {
    width: calc(30% - 50px);
    margin: 25px;
  }
}
@media (min-width: 1367px) {
  .contact-block .contact-items {
    margin: -50px;
  }
  .contact-block .contact-items .main {
    width: calc(70% - 100px);
    margin: 50px;
  }
  .contact-block .contact-items aside {
    width: calc(30% - 100px);
    margin: 50px;
  }
}
.contact-block .contact-items aside .contact-variants .item {
  text-align: center;
  margin-bottom: clamp(25px, 4vw, 60px);
}
@media (max-width: 1023px) {
  .contact-block .contact-items aside .contact-variants .item:last-child {
    margin-bottom: 0;
  }
}
.contact-block .contact-items aside .contact-variants .item .content {
  line-height: 1.4;
}
.contact-block .contact-items aside .contact-variants .item .content .label {
  font-family: 'Abhaya Libre', serif;
  font-weight: 400;
  margin-bottom: 15px;
}
.contact-block .contact-items aside .contact-variants .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;
}
.contact-block .contact-items aside .contact-variants .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);
}
@media (min-width: 1024px) {
  .contact-block .contact-items aside .contact-variants {
    height: 100%;
    display: flex;
    flex-direction: column;
  }
}
.contact-block .contact-items aside .item .content > a.img-link {
  display: inline-block;
  position: relative;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  margin-right: 10px;
}
.contact-block .contact-items aside .item .content > a.img-link:last-child {
  margin-right: 0;
}
.contact-block .contact-items 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;
}
