@charset "UTF-8";
/*
55.     Bootstrap Notice
60.     Font Family
210.    Headings
270.    Paragraphs & Lists
390.    Muted Text
410.    Hyperlinks
470.    Backgrounds
540.    Card Grid
610.    Equal Height Rows/Columns
630.    Animation
670.    Other Basics
910.    Buttons
1500.   Decorative Gradient Stripe
1520.   Video
1570.   Containers
1670.   Parallax Container
1710.   Image Overlay
1860.   Dark Transparent Overlay
1890.   Rows & Columns
2430.   Reverse Columns
2470.   List Group
2480.   Table
2610.   Camerata
2980.   Login Nav
3060.   Nav
3170.   Accordion
3220.   Four Item Carousel
3310.   Two Column Slider
3440.   Product Slider 1
3560.   Product Slider 2
3620.   Main Menu
3740.   Mobile Menu
3830.   Desktop Navigation
3860.   Mobile Nav
4020.   Mobile Menu
4060.   Submenus
4120.   Mobile Submenu
4480.   Mega Menu                       
4680.   Footer                            
4720.   Call To Action
4770.   Filter Divs
5140.   Spacing
6320.   Centering
6370.   Alignment
6430.   Text-Wrap Columns
6440.   Page Loader
6550.   Skip To Content
6580.   Small Screens




Bootstrap v5.1.3 (https://getbootstrap.com/)
 * Copyright 2011-2021 The Bootstrap Authors
 * Copyright 2011-2021 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
*/ 
/* =================== FONT FAMILY ===================  */

  /*  Satoshi is an open-source font that is modern, simple, clean, easily read and free to use without royalty.
      Satoshi is also available in a wide range of weights so there is no need to set weights for this font.
      Simply select the appropriate variant - see the font classes created below.  */
      
  /*  Any other font can be installed in /webfonts and then given names here.  You then need to change the font
      variables in 'variables.css' to use the new font in the website.  */

@font-face {
    font-family: OladraFont;
    src: url('https://camerata.app/webfonts/oladrafont.woff2') format('woff2'),
		url('https://camerata.app/webfonts/oladrafont.woff') format('woff');
    font-weight: 400;
    font-style: normal;
    font-stretch: normal;
    unicode-range: U+0020-007A;
}
@font-face {
  font-family: SatoshiLight;
  src: url('https://camerata.app/webfonts/Satoshi-Light.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-Light.woff') format('woff');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: SatoshiLightItalic;
  src: url('https://camerata.app/webfonts/Satoshi-LightItalic.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-LightItalic.woff') format('woff');
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: SatoshiRegular;
  src: url('https://camerata.app/webfonts/Satoshi-Regular.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: SatoshiRegularItalic;
  src: url('https://camerata.app/webfonts/Satoshi-RegularItalic.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-RegularItalic.woff') format('woff');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: SatoshiMedium;
  src: url('https://camerata.app/webfonts/Satoshi-Medium.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-Medium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: SatoshiMediumItalic;
  src: url('https://camerata.app/webfonts/Satoshi-MediumItalic.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-MediumItalic.woff') format('woff');
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: SatoshiBold;
  src: url('https://camerata.app/webfonts/Satoshi-Bold.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-Bold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: SatoshiBoldItalic;
  src: url('https://camerata.app/webfonts/Satoshi-BoldItalic.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-BoldItalic.woff') format('woff');
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: SatoshiBlack;
  src: url('https://camerata.app/webfonts/Satoshi-Black.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-Black.woff') format('woff');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: SatoshiBlackItalic;
  src: url('https://camerata.app/webfonts/Satoshi-BlackItalic.woff2') format('woff2'),
       url('https://camerata.app/webfonts/Satoshi-BlackItalic.woff') format('woff');
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
    font-family: SatoshiVariable;
    src: url('https://camerata.app/webfonts/Satoshi-Variable.woff2') format('woff2'),
         url('https://camerata.app/webfonts/Satoshi-Variable.woff') format('woff');
  font-weight: 1 900; /* Supports full range of weights */
  font-style: normal;
  font-display: swap;
}
@font-face {
    font-family: SatoshiVariableItalic;
    src: url('https://camerata.app/webfonts/Satoshi-VariableItalic.woff2') format('woff2'),
         url('https://camerata.app/webfonts/Satoshi-VariableItalic.woff') format('woff');
  font-weight: 1 900; /* Supports full range of weights */
  font-style: normal;
  font-display: swap;
}
@font-face {
    font-family: Playfair;
    src: url('https://camerata.app/webfonts/playfairdisplay-variablefont_wght-webfont.woff2') format('woff2'),
         url('https://camerata.app/webfonts/playfairdisplay-variablefont_wght-webfont.woff') format('woff');
  font-weight: 1 900; /* Supports full range of weights */
  font-style: normal;
  font-display: swap;
}
@font-face {
    font-family: PlayfairItalic;
    src: url('https://camerata.app/webfonts/playfairdisplay-italic-variablefont_wght-webfont.woff2') format('woff2'),
         url('https://camerata.app/webfonts/playfairdisplay-italic-variablefont_wght-webfont.woff') format('woff');
  font-weight: 1 900; /* Supports full range of weights */
  font-style: normal;
  font-display: swap;
}











/* ============= HEADINGS ================ */

h1,
h2,
h3,
h4 {
    font-family: var(--font-brand);
    color: var(--heading-text);
    text-transform: lowercase;
    font-weight: 100;
}
.h1,
.h2,
.h3,
.h4 {
    font-family: var(--font-brand);
    color: var(--heading-text);
    text-transform: lowercase;
    font-weight: 100;
}
h1 {
  font-size: var(--h1);
  line-height: var(--h1l);
}

.h1 {
  font-size: var(--h1);
  line-height: var(--h1l);
}

h2 {
  font-size: var(--h2);
  line-height: var(--h2l);
}
.h2 {
  font-size: var(--h2);
  line-height: var(--h2l);
}

h3 {
  font-size: var(--h3);
  line-height: var(--h3l);
}
.h3 {
  font-size: var(--h3);
  line-height: var(--h3l);
}

h4 {
  font-size: var(--h4);
  line-height: var(--h4l);
}
.h4 {
  font-size: var(--h4);
  line-height: var(--h4l);
}

/*h1,
h2,
h3,
h4 {
    font-family: var(--font-brand);
    color: var(--heading-text);
    margin-top: 1rem;
    margin-bottom: 1rem;
    line-height: 1.8rem;
}



/* ============= PARAGRAPHS & LISTS ================ */

p {
    font-family: var(--font-body);
    color: var(--body-text);
    margin-top: 0;
    margin-bottom: 1.25rem;
    line-height: 1.5rem;
}
p.compressed {
    margin: 0;
}
.lowered {
    padding-top: 0.7vw;
    padding-bottom: 0.7vw;
    margin-top: 0;
    margin-bottom: 0;
}
.light {
    font-family: var(--font-light)!important;
}
.regular {
    font-family: var(--font-regular)!important;
}
.medium {
    font-family: var(--font-medium)!important;
}
.bold {
    font-family: var(--font-bold)!important;
}
.black {
    font-family: var(--font-black)!important;
}
.brand-font {
    font-family: var(--font-brand);
}

/* Subheadings */

.subheading {
    font-family: var(--font-regular);
    color: var(--body-text);
    margin-top: 0;
    margin-bottom: 0;
    font-size: var(--p1);
    line-height: var(--p1l);
}
.uppercase-subheading {
    font-family: var(--font-regular);
    color: var(--body-text);
    margin-top: 0;
    margin-bottom: 0;
    font-size: var(--p1);
    line-height: var(--p1l);
    text-transform: uppercase!important;
}

/* P1 */

.p1,
.p1 ul,
.p1 ol,
.p1 li {
  font-size: var(--p1);
  line-height: var(--p1l);
  font-family: var(--font-body);
  color: var(--body-text);
}

/* P2 */
.p2,
.p2 ul,
.p2 ol,
.p2 li {
  font-size: var(--p2);
  line-height: var(--p2l);
  font-family: var(--font-body);
  color: var(--body-text);
}

/* P3 */
.p3,
.p3 ul,
.p3 ol,
.p3 li {
  font-size: var(--p3);
  line-height: var(--p3l);
  font-family: var(--font-body);
  color: var(--body-text);
}

/* P4 */
.p4,
.p4 ul,
.p4 ol,
.p4 li {
  font-size: var(--p4);
  line-height: var(--p4l);
  font-family: var(--font-body);
  color: var(--body-text);
}

ul, 
ol { 
  padding-left: 1.5em;   /* Indent list */
  margin-bottom: 1em;    /* Space below list */
  list-style-position: outside;
}

b {
  font-family: var(--font-regular);
}

.small,
small {
  font-size: 0.875em;
}

sub {
  position: relative;
  font-size: 0.75em;
  line-height: 0;
  vertical-align: baseline;
  bottom: -0.25em;
}

pre {
  font-family: var(--bs-font-monospace);
  font-size: 1em;
  direction: ltr;
  unicode-bidi: bidi-override;
  display: block;
  margin-top: 0;
  margin-bottom: 1rem;
  overflow: auto;
  font-size: 0.875em;
}

.inline-error-outline {
    outline: 2px solid var(--error, #b00020);
    outline-offset: 2px; 
}




/* ============= MUTED TEXT ================ */

h1.muted,
h2.muted,
h3.muted,
h4.muted,
p.muted,
.muted {
  color: var(--muted-text);
}
h1.semi-muted,
h2.semi-muted,
h3.semi-muted,
h4.semi-muted,
p.semi-muted,
.semi-muted {
  color: var(--semi-muted-text);
}


/* ============= HYPERLINKS ================ */


a {
  color: var(--link-text);
  font-family: var(--font-regular);
  text-decoration: none;
  transition: color 0.2s ease;
}
a:hover {
  color: var(--link-accent);
}
a:active {
  color: var(--link-accent);
}
a.cta {
  color: var(--cta-text);
}
a.cta:hover {
  color: var(--cta-accent);
}
a.cta:active {
  color: var(--cta-accent);
}
a.luxe {
  color: var(--luxe-text);
  font-family: var(--font-medium);
  font-size: var(--p2);
}
a.luxe:hover {
    color: var(--luxe-accent);
    text-decoration: underline solid var(--luxe-accent) 1px;
    text-underline-offset: 15px;
}
a.luxe:active {
    color: var(--luxe-accent);
    text-decoration: underline solid var(--luxe-accent) 1px;
    text-underline-offset: 15px;
}
a.luxe1 {
  color: var(--luxe-text);
  font-family: var(--font-medium);
  font-size: var(--p1);
}
a.luxe1:hover {
    color: var(--luxe-accent);
    text-decoration: underline solid var(--luxe-accent) 1px;
    text-underline-offset: 15px;
}
a.luxe1:active {
    color: var(--luxe-accent);
    text-decoration: underline solid var(--luxe-accent) 1px;
    text-underline-offset: 15px;
}
.dummy-link {
    color: var(--luxe-accent);
    text-decoration: underline solid var(--luxe-accent) 1px;
    text-underline-offset: 15px;
    font-family: var(--font-medium);
}
.text-link {
    color: var(--highlight-text);
}
.naked {
  text-decoration: none ;
}
.naked a {
  text-decoration: none ;
}
.naked a:hover {
  text-decoration: none ;
}
.uppercase {
    text-transform: uppercase!important;
}
.lowercase {
    text-transform: lowercase!important;
}

/* Any hash target gets this margin so it won't hide under the sticky header */
#login {
  scroll-margin-top: var(--nav-offset);
}




/*  ===================  BACKGROUNDS  ========================  */
  /* For every <section> or <div> set the background colour using one of the following classes  */


.page-header {
    background: var(--page-bg);
    padding-top: var(--menu-height);
}
.equipment-header {
    background: var(--equipment-gradient);
    background-blend-mode: multiply;
    padding-top: var(--menu-height);
}
.light-header {
    background: var(--section-bg);
    padding-top: var(--menu-height);
}
.highlight-header {
    background: var(--highlight-bg);
    padding-top: var(--menu-height);
}
/*@media (max-width: 1024px) {
    .highlight-header,
    .light-header,
    .equipment-header,
    .page-header {
        margin-top: calc(80px - var(--menu-height));
    }
} */
.page-section {
    background: var(--page-bg);
    color: var(--body-text);
}
.light-section {
    background: var(--section-bg);
    color: var(--body-text);
}
.highlight-section {
    background: var(--highlight-bg);
    color: var(--body-text);
}
.primary-border {
    border: 1px solid var(--primary-border);
}
.panel {
    width: 100%;
}
.light-bg {
    background: var(--light-bg);
}










/* ======================== CARD GRID ==================== */


.card0 {
    background: var(--highlight-bg);
    border-radius: 1px;
    display: flex;
    flex-direction: column;
    padding: 24px;
}
.card1 {
    background: var(--primary-brand);
    color: var(--button-text);
    border: 1px solid var(--panel-border);
    border-radius: 16px;
    box-shadow: var(--shadow-large);
    display: flex;
    flex-direction: column;
    padding: 24px;
}
.dark-text {
    color: var(--dark-text);
}
.card2 {
    background: var(--light-bg);
    color: var(--dark-text)!important;
    border: 1px solid var(--panel-border);
    border-radius: 16px;
    box-shadow: var(--shadow-large);
    display: flex;
    flex-direction: column;
    padding: 24px;
}
.card3 {
    background: #555555;
    border: 1px solid var(--primary-border);
    border-radius: 16px;
    box-shadow: var(--shadow-large);
    display: flex;
    flex-direction: column;
    padding: 24px;
}
.card {
    background: var(--section-bg);
    border: none;
    border-radius: 16px;
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    padding: 24px;
}
.cards-grid1 {
    display: grid;
    gap: 16px;                    /* identical vertical + horizontal gaps */
}

/* stack on tablets/phones */
    @media (max-width: 1024px) {
    .cards-grid1 { grid-template-columns: 1fr; }
}

/* 2-col on desktop; right spans both rows */
@media (min-width: 1025px) {
    .cards-grid1 {
      grid-template-columns: 1fr 1fr;   /* or 2fr 1fr, your call */
      grid-template-rows: auto auto;
      grid-template-areas:
        "left-top   right"
        "left-bottom right";
      align-items: stretch;
    }
    .left-top    {
        grid-area: left-top; 
    }
    .left-bottom {
        grid-area: left-bottom;
    }
    .right-span  { 
        grid-area: right;
        height: 100%;
    }
}










/* ======================== EQUAL HEIGHT ROWS/COLUMNS ==================== */

    .row.equal-height-row { align-items: stretch; }        /* stretch cols */
    .row.equal-height-row > [class*="col-"] { display:flex; }          /* make each col a flex box */
    .row.equal-height-row > [class*="col-"] > .panel.card {
      display:flex;                       /* allow inner layout */
      flex: 1 1 auto;                     /* fill the column height */
      width: 100%;                        /* avoid shrink */
    }











/* ======================== ANIMATION ===================== */

/*========= On Scroll ==========*/

@keyframes fadeInUp {
  from {
    transform: translateY(50px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
.fade-in-up {
    animation: var(--animation-duration) both fadeInUp;
    animation-delay: var(--animation-delay);
}

/*========== Static ===========*/

@keyframes fadeInUpStatic {
  0% {
    transform: translateY(100%);
    opacity: 0;
  }
  100% {
    transform: translateY(0%);
    opacity: 1;
  }
}

.fadeInUp-Static {
    animation: var(--animation-duration) both fadeInUp;
    animation-delay: var(--animation-delay);
}

/* Cross-fade wrapper */
.colour-wrap {
  position: relative;
  width: 100%;
}

/* Both images sit on top of each other */
.colour-wrap .colour-img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: auto;
  opacity: 0;
  transition: opacity 2s ease;
}

/* Ensure the wrapper has height (prevents collapse) */
.colour-wrap .colour-img.active {
  opacity: 1;
  position: relative; /* gives the wrapper its height */
}



/* ======================== OTHER BASICS ===================== */


* {
  scrollbar-color: var(--cta-accent) var(--page-bg);
}
/* Works on Chrome, Edge, and Safari */
*::-webkit-scrollbar {
  width: 12px;
}
*::-webkit-scrollbar-track {
  background:  var(--page-bg);
}
*::-webkit-scrollbar-thumb {
  background-color: var(--cta-accent);
  border-radius: 20px;
  border: 1px solid var(--page-bg);
}
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
@media (prefers-reduced-motion: no-preference) {
  :root {
    scroll-behavior: smooth;
  }
}
body,
html {
  height: 100%;
  background: var(--page-bg); 
  font-size: var(--p2)!important; 
  font-family: var(--font-body)!important; 
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
html {
  -ms-overflow-style: scrollbar;
  scroll-behavior: smooth;
  scroll-padding-top: 6rem;
}
body {
  margin: 0;
  overflow-y: auto;
  overflow-x: hidden;
} 
.center-row {
  display: flex;
  justify-content: center;
}
.relative {
  position: relative!important;
}
.stick-fixed {
  position: fixed !important;
  top: 0;
  left: 0;
}
@media (max-width: 1024px) {
    .stick-fixed {
        position: fixed !important;
    }
}
.hidden {
  display: none!important;
}
.clearlist,
.clearlist li {
  list-style: none;
  padding: 0;
  margin: 0;
  background: 0 0;
}
.panel-border {
  -webkit-box-flex: 1;
  flex: 1 1 auto;
  padding: 1.25rem;
  background: var(--page-bg);
  border: solid 1px var(--panel-border);
  border-radius: 22px;
  margin-top: 50px;
  box-shadow: 0 5px 7px 0 var(--dark-bg);  
}
.img {
    width: 100%!important;
    height: auto;
    vertical-align: middle;
} 
img:not([draggable]),
video {
  max-width: 100%;
  height: auto;
}
iframe {
  border: 0;
}
.responsive-iframe {  position: absolute;  top: 0;  left: 0;  bottom: 0;  right: 0;  width: 100%;  height: 100%;}

iframe {
  border: none;
}
.divider {
  width: 100%;
  border: 0;
  height: 1px;
  background-color: var(--divider)!important;
  opacity: 1;
}

/* Non-invasive field highlight for inline errors (no layout shift) */
.inline-error-outline { 
    outline: 2px solid var(--error, #b00020); 
    outline-offset: 2px; 
}
.nav-logo-wrap .brand-image,
.mobile-logo-wrap .brand-image {
  display: block;
  width: 190px;
  height: 40px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: var(--brand-image, url('/images/oladra-menu-horizontal.png'));
  margin-top: -4px;
}
.mobile-logo-wrap .brand-image {
  position: relative;
  z-index: 9999;
  pointer-events: auto;
}

.footer-logo .brand-image {
  width: 190px;
  height: 40px;
  max-width: 100%;
  max-height: 100%;
  padding-bottom: 30px; 
  padding-right: 5vw;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain; 
  background-image: var(--brand-image, url('/images/oladra-menu-horizontal.png'));
}
.body-logo .brand-logo {
  display: block;
  width: 45px;
  height: 45px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: var(--brand-logo, url('/images/oladra_logo_light.png'));
}
.brand-wrapper {
  display: flex;
  align-items: center; /* vertically center logo and text */
  gap: 10px;           /* spacing between logo and text */
}
.brand-wrapper .brand-logo {
  display: inline-block;
  width: 45px;
  height: 45px;
  vertical-align: middle;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: var(--brand-logo, url('/images/oladra_logo_light.png'));
}

/* ===== Mobile top bar: center the logo, keep burger & login clickable ===== */
.mobile-top-bar { position: relative; } /* safety */

.mobile-top-bar .mobile-logo-wrap {
  position: absolute;               /* independent of the left/right items */
  left: 50%;
  transform: translateX(-50%);
  top: calc(var(--mob-menu-padding, 10px)); /* adjust if you want it higher/lower */
  display: flex;
  align-items: center;
  height: 28px;                     /* same visual height as the burger */
  z-index: 1;                       /* sits under the burger/login (which get z=2 below) */
  pointer-events: auto;
}

/* Ensure burger & login stay on top and clickable */
.mobile-top-bar .mobile-menu-toggle,
.mobile-top-bar .mobile-login {
  position: relative;
  height: 48px;
  z-index: 2;
}

/* Your existing background-image rules already size the logo nicely */
.mobile-logo-wrap .brand-image {
  display: block;
  width: 190px;
  height: 40px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: var(--brand-image, url('/images/oladra-menu-horizontal.png'));
  margin-top: 28px;
}

/* ===== Footer: center logo & related bits on mobile ===== */
@media (max-width: 1024px) {
  .footer-logo,
  .align-footer-image {
    text-align: center !important;
  }
  .footer-logo .brand-image {
    margin-left: auto;
    margin-right: auto;
    display: block;
    width: 190px;   /* keep your chosen size */
    height: 40px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    background-image: var(--brand-image, url('/images/oladra-menu-horizontal.png'));
  }
}
/* === Mobile logo click fix: do not change layout, only click routing === */
@media (max-width: 1024px) {
  /* The bar itself should not swallow pointer events */
  .mobile-top-bar {
    pointer-events: none;
  }

  /* But its direct children (burger, logo wrapper, login) should */
  .mobile-top-bar > * {
    pointer-events: auto;
  }
}
/* === FINAL MOBILE LOGO CLICK FIX === */
@media (max-width: 1024px) {

  /* 1. Free the center zone by removing overlapping flex boxes */
  .mobile-top-bar {
    position: relative;
    height: 48px; /* fixed height for alignment */
  }

  /* 2. Left: burger */
  .mobile-top-bar .mobile-menu-toggle {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3; /* stays clickable */
  }

  /* 3. Center: logo (already absolute in your CSS, leave it) */
  .mobile-top-bar .mobile-logo-wrap {
    z-index: 4; /* now safely above all */
  }

  /* 4. Right: login button */
  .mobile-top-bar .mobile-login {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3; /* stays clickable */
  }
}














/* ==========================  BUTTONS  ====================== */

button:focus:not(:focus-visible) {
  outline: 0;
}
input,
select {
  margin: 0;
    font-size: var(--p2)!important; 
    font-family: var(--font-body)!important; 
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  font-size: var(--p3);
  font-family: var(--font-body) !important;
  -webkit-text-fill-color: var(--muted-text) !important;
  box-shadow: 0 0 0 1000px var(--highlight-bg) inset !important;
  border: 1px solid var(--panel-border)!important;
  -webkit-box-shadow: 0 0 0 36px var(--page-bg) inset !important;
} 
.btn-group button {
  flex: 0 0 auto;
}
button,
select {
  text-transform: none;
}
[role="button"] {
  cursor: pointer;
}
select {
  word-wrap: normal;
}
select:disabled {
  opacity: 1;
}
[list]::-webkit-calendar-picker-indicator {
  display: none;
}
[type="button"],
[type="reset"],
[type="submit"],
button {
  -webkit-appearance: button;
}
[type="button"]:not(:disabled),
[type="reset"]:not(:disabled),
[type="submit"]:not(:disabled),
button:not(:disabled) {
  cursor: pointer;
/*  background: var(--primary-brand);
  color: var(--button-text);*/
  border: none; 
}
button {
    white-space: nowrap;
}
button.button-transparent {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border-color: transparent;
  outline: none;
  cursor: pointer;
  padding: 0.9rem 2rem;
  width: calc(150px + 5vw)!important;
  max-width: 100%!important;
  background-color: transparent;
  font-family: var(--font-body);
  font-size: var(--p1);
  line-height: var(--p1l);
  color: var(--muted);         
  text-transform: uppercase;
  text-decoration: none !important;
  opacity: 1;
}
button.button-transparent:hover {
  background: transparent;
  color: var(--highlight-text);
}
button.button-transparent:active {
  background: transparent;
  color: var(--highlight-text);
}
button.button-outline {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border: 1px solid var(--semi-muted-text)!important;
  border-radius: 40px;
  outline: none;
  cursor: pointer;
  padding: 0.9rem 2rem;
  width: calc(150px + 5vw)!important;
  max-width: 100%!important;
  background-color: transparent;
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--body-text);         
  text-decoration: none !important;
  opacity: 1;
}
button.button-outline:hover {
  background: transparent;
  color: var(--heading-text);
  border: 1px solid var(--body-text)!important;
}
button.button-outline:active {
  background: transparent;
  color: var(--heading-text);
  border: 1px solid var(--body-text)!important;
}
button.button-outline-small {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border: 1px solid var(--semi-muted-text)!important;
  border-radius: 40px;
  outline: none;
  cursor: pointer;
  padding: 0.9rem 1rem;
  width:  calc(80px + 5vw)!important;
  max-width: 100%!important;
  background-color: transparent;
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--body-text);         
  text-decoration: none !important;
  opacity: 1;
}
button.button-outline-small:hover {
  background: transparent;
  color: var(--heading-text);
  border: 1px solid var(--body-text)!important;
}
button.button-outline-small:active {
  background: transparent;
  color: var(--heading-text);
  border: 1px solid var(--body-text)!important;
}
button.button-outline-tiny {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border: 1px solid var(--semi-muted-text)!important;
  border-radius: 20px;
  outline: none;
  cursor: pointer;
  padding: 0.1rem 1rem;
  width: calc(100px + 2vw)!important;
  max-width: 100%!important;
  background-color: transparent;
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--body-text);         
  text-decoration: none !important;
  opacity: 1;
}
button.button-outline-tiny:hover {
  background: transparent;
  color: var(--heading-text);
  border: 1px solid var(--body-text)!important;
}
button.button-outline-tiny:active {
  background: transparent;
  color: var(--heading-text);
  border: 1px solid var(--body-text)!important;
}
button.button-outline-round {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border: 1px solid var(--semi-muted-text)!important;
  border-radius: 30px;
  outline: none;
  cursor: pointer;
  width: 40px;
  height: 40px;
  background-color: transparent;
  font-family: var(--font-body);
  font-size: 1.5rem;
  padding-bottom: 0.15rem;
  line-height: var(--p3l);
  color: var(--body-text);         
  text-decoration: none !important;
  opacity: 1;
}
button.button-outline-round:hover {
  background: transparent;
  color: var(--heading-text);
  border: 1px solid var(--highlight-text)!important;
}
button.button-outline-round:active {
  background: transparent;
  color: var(--heading-text);
  border: 1px solid var(--highlight-text)!important;
}
button.button-primary {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border-radius: 40px;
  outline: none;
  cursor: pointer;
  padding: 0.9rem 2rem;
  width: calc(150px + 5vw)!important;
  max-width: 100%!important;
  background-color: var(--primary-brand);
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--button-text);         
  text-decoration: none !important;
  opacity: 1;
  box-shadow: var(--shadow);  
}
button.button-primary:hover {
    background: var(--primary-brand);
    background: var(--primary-gradient);
}
button.button-primary:active {
    background: var(--primary-brand);
    background: var(--primary-gradient);
}
button.button-primary-small {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border-radius: 40px;
  outline: none;
  cursor: pointer;
  padding: 0.9rem 1rem;
  width: calc(80px + 5vw)!important;
  max-width: 100%!important;
  background-color: var(--primary-brand);
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--button-text);         
  text-decoration: none !important;
  opacity: 1;
  box-shadow: var(--shadow);  
}
button.button-primary-small:hover {
    background: var(--primary-brand);
    background: var(--primary-gradient);
}
button.button-primary-small:active {
    background: var(--primary-brand);
    background: var(--primary-gradient);
}
button.button-primary-tiny {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border-radius: 20px;
  outline: none;
  cursor: pointer;
  padding: calc(0.1rem + 1px) 1rem; 
/*  width: auto; */
  width: calc(100px + 2vw)!important;
  max-width: 100%!important;
  background-color: var(--primary-brand);
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--button-text);         
  text-decoration: none !important;
  opacity: 1;
  box-shadow: var(--shadow);  
}
button.button-primary-tiny:hover {
    background: var(--primary-brand);
    background: var(--primary-gradient);
}
button.button-primary-tiny:active {
    background: var(--primary-brand);
    background: var(--primary-gradient);
}
button.button-luxe {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border-radius: 40px;
  outline: none;
  cursor: pointer;
  padding: 0.9rem 2rem;
/*  width: auto; */
  width: calc(150px + 5vw)!important;
  max-width: 100%!important;
  height: calc(39px + 0.2vw);
  background-color: var(--luxe-accent);
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--button-text);         
  text-decoration: none !important;
  opacity: 1;
  box-shadow: var(--shadow);  
}
button.button-luxe:hover {
    background: var(--luxe-accent);
    background: var(--luxe-gradient);
}
button.button-luxe:active {
    background: var(--luxe-accent);
    background: var(--luxe-gradient);
}
button.button-luxe-small {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border-radius: 40px;
  outline: none;
  cursor: pointer;
  padding: 0.9rem 1rem;
  width: calc(80px + 5vw)!important;
  max-width: 100%!important;
  background-color: var(--luxe-accent);
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--button-text);         
  text-decoration: none !important;
  opacity: 1;
  box-shadow: var(--shadow);  
}
button.button-luxe-small:hover {
    background: var(--luxe-accent);
    background: var(--luxe-gradient);
}
button.button-luxe-small:active {
    background: var(--luxe-accent);
    background: var(--luxe-gradient);
    color: var(--highlight-text);
}
button.button-luxe-tiny {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  border-radius: 20px;
  outline: none;
  cursor: pointer;
  padding: 0.1rem 1rem;
  width: calc(40px + 4vw)!important;
  max-width: 100%!important;
  height: calc(39px + 0.2vw);
  background-color: var(--luxe-accent);
  font-family: var(--font-body);
  font-size: var(--p3);
  line-height: var(--p3l);
  color: var(--button-text);         
  text-decoration: none !important;
  opacity: 1;
  box-shadow: var(--shadow);  
}
button.button-luxe-tiny:hover {
    background: var(--luxe-accent);
    background: var(--luxe-gradient);
}
button.button-luxe-tiny:active {
    background: var(--luxe-accent);
    background: var(--luxe-gradient);
}
button.button-link {
  display: inline-block;
  align-items: center;
  text-align: center;
  justify-content: center;
  outline: none;
  cursor: pointer;
  width: auto;
  font-family: var(--font-body);
  font-size: var(--p2);
  line-height: var(--p3l);
  background: transparent;
  color: var(--luxe-accent);         
  text-transform: none;
  text-decoration: none !important;
  opacity: 1;
}
button.button-link:hover {
  color: var(--luxe-accent);
}
button.button-link:active {
  color: var(--luxe-accent);
}

button.button-icon {
  display: inline-block;
  background: transparent; 
  align-items: center;
  text-align: center;
  justify-content: center;
  border: 1px solid var(--primary-border);
  outline: none;
  cursor: pointer;
  width: auto;
  height: 46px;
  width: 46px;
  border-radius: 10px;
  text-decoration: none !important;
  opacity: 1;
}
button.button-icon:hover {
  background: var(--luxe-text);
  border: none;
  opacity: 1;
}
button.button-icon:active {
  background: var(--luxe-text);
  border: none;
  opacity: 1;
}

#buttontop {
  display: inline-block;
  color: var(--highlight-text);
  background-color: transparent;
  opacity: 0.4!important;
  box-shadow: 0 5px 7px 0 rgba(0, 0, 0, 0.3);  
  width: 50px;
  height: 50px;
  font-size: 18px; /* set the font size */
  text-align: center;
  padding-top: 11px;
  border: 1px solid var(--highlight-text);
  border-radius: 50%;
  position: fixed;
  bottom: calc(5vmin + 55px); /* set the distance from the bottom of the screen */
  left: 40px;
  transition: background-color .2s, 
    opacity .3s, visibility .3s;
  visibility: hidden;
  z-index: 1000;
}
#buttontop::after {
  font-size: 2em;
  line-height: 50px;
  color: #000;
}
#buttontop:hover {
  cursor: pointer;
  background: transparent;
  color: var(--highlight-text);
  border: 1px solid var(--highlight-text);
  text-decoration: none;
  opacity: 1!important;
}
#buttontop:active {
  background: transparent;
  color: var(--highlight-text);
  border: 1px solid var(--highlight-text);
  text-decoration: none;
}
#buttontop.show {
  opacity: 1;
  visibility: visible;
}

.btn-group,
.btn-group-vertical {
  position: relative;
  display: inline-flex;
  vertical-align: middle;
}
.btn-group-vertical > .btn,
.btn-group > .btn {
  position: relative;
  flex: 1 1 auto;
}
.btn-group-vertical > .btn-check:checked + .btn,
.btn-group-vertical > .btn-check:focus + .btn,
.btn-group-vertical > .btn.active,
.btn-group-vertical > .btn:active,
.btn-group-vertical > .btn:focus,
.btn-group-vertical > .btn:hover,
.btn-group > .btn-check:checked + .btn,
.btn-group > .btn-check:focus + .btn,
.btn-group > .btn.active,
.btn-group > .btn:active,
.btn-group > .btn:focus,
.btn-group > .btn:hover {
  z-index: 1;
}
.btn-group > .btn-group:not(:first-child),
.btn-group > .btn:not(:first-child) {
  margin-left: 10px;
}
.btn-group > .btn-group:not(:last-child) > .btn,
.btn-group > .btn:not(:last-child):not(.dropdown-toggle) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.btn-group > .btn-group:not(:first-child) > .btn,
.btn-group > .btn:nth-child(n + 3),
.btn-group > :not(.btn-check) + .btn {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.btn-group-vertical {
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
.btn-group-vertical > .btn,
.btn-group-vertical > .btn-group {
  width: 100%;
}
.btn-group-vertical > .btn-group:not(:first-child),
.btn-group-vertical > .btn:not(:first-child) {
  margin-top: -1px;
}
.btn-group-vertical > .btn-group:not(:last-child) > .btn,
.btn-group-vertical > .btn:not(:last-child):not(.dropdown-toggle) {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.btn-group-vertical > .btn-group:not(:first-child) > .btn,
.btn-group-vertical > .btn ~ .btn {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.btn-group-wrap {
  display: flex;
  flex-wrap: wrap;     /* Allow wrapping */
  gap: 10px;           /* Space between buttons */
  justify-content: flex-start; /* Default: left align */
}

.btn-group-wrap .button-primary,
.btn-group-wrap .button-outline {
  flex: 0 0 auto;      /* No stretching */
  white-space: nowrap; /* Keep text on one line */
}

/* Center aligned version (wraps stay centered) */
.btn-group-wrap.btn-center {
  justify-content: center;
}

/* Right aligned version (optional) */
.btn-group-wrap.btn-right {
  justify-content: flex-end;
}

@media (max-width: 1024px) {
    .btn-group-wrap.btn-right {
      justify-content: center;
    }
}

.button-text {
      color: var(--button-text)!important;         
}

/*  Image-Buttons */

/* Header row: forces h2 + icon inline */
.section-header {
  display: flex;
  align-items: center;
  gap: 14px;
}

/* Neutralise any global h2 margins */
.section-title {
  margin: 0;
  line-height: 1.1;
}

/* Icon link container */
.section-icon {
  position: relative;
  width: 40px;   /* adjust */
  height: 40px;
  padding-bottom: 20px;
  display: inline-block;
  flex-shrink: 0;
}

/* Base icon */
.section-icon .open-icon,
.section-icon .hover-open-icon {
  position: absolute;
  inset: 0;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transition: opacity 0.18s ease;
}

/* Image sources */
.section-icon .open-icon {
  background-image: url("../images/open-icon.png");
  opacity: 1;
  height: 35px;
}

.section-icon .hover-open-icon {
  background-image: url("../images/hover-open-icon.png");
  opacity: 0;
}

/* Hover swap */
.section-icon:hover .open-icon {
  opacity: 0;
}

.section-icon:hover .hover-open-icon {
  opacity: 1;
}

/* Hide button but keep it accessible to JS */
.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}













/*  =================== DECORATIVE GRADIENT STRIPE ========================= */


.gradient-block {
  display: flex; /* Places stripe and text side-by-side */
  align-items: stretch; /* Ensures stripe matches text height */
}

.gradient-stripe {
  width: 4px;
  background: linear-gradient(to bottom, #a67c52, #403020); /* Example gradient */
  flex-shrink: 0; /* Prevent stripe from shrinking */
}

.gradient-text {
  padding-left: 3em; /* Space between stripe and text */
}



/*  =================== VIDEO ========================= */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.video-container {
  position: relative;
  height: 100vh;
  width: 100vw;
  overflow: hidden;
}

.background-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 100vh;
  object-fit: cover;
  transform: translate(-50%, -50%);
  z-index: -1;
}

.overlay-content {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 50%;
  height: auto;
  transform: translate(-50%, -50%);
  color: var(--page-bg);
  text-align: center;
  z-index: 1;
}
@media (max-width: 1500px) {
  .overlay-content {
    width: 55%;
  }
}
@media (max-width: 767px) {
  .overlay-content {
    width: 70%;
  }
}



/* =================  CONTAINERS  ======================= */


.full-wrapper {
  margin: 0 2%;
}
.full-width-section {
    width: 100%;
}
.container {
  width: 100%;
  padding: 0 2vw 0 2vw;
  margin-right: auto!important;
  margin-left: auto!important;
}
.container-wide {
  max-width: 2400px;
  padding: 0 2vw 0 2vw;
  margin-right: auto!important;
  margin-left: auto!important;
} 
.container-med {
  max-width: 2000px;
  padding: 0 2vw 0 2vw;
  margin-right: auto!important;
  margin-left: auto!important;
}
.container-slim {
  max-width: 1600px;
  padding: 0 2vw 0 2vw;
  margin-right: auto!important;
  margin-left: auto!important;
}
.container-slimmer {
  max-width: 1200px;
  padding: 0 2vw 0 2vw;
  margin-right: auto!important;
  margin-left: auto!important;
}
.container-slimmest {
  max-width: 900px;
  padding: 0 2vw 0 2vw;
  margin-right: auto!important;
  margin-left: auto!important;
}
.rounded-section {
  border-radius: calc(2vw + 2vh);
  padding: 20px;
}
@media (min-width: 576px) {
  .container, .container-wide, .container-med, .container, .container-slim, .container-slimmer, .container-slimmest {
    max-width: 540px;
  }
}
@media (min-width: 768px) {
  .container, .container-wide, .container-med, .container, .container-slim, .container-slimmer, .container-slimmest {
    max-width: 720px;
  }
}
@media (min-width: 992px) {
  .container, .container-wide, .container-med, .container, .container-slim, .container-slimmer {
    max-width: 882px;
  }
}
@media (min-width: 1200px) {
  .container, .container-wide, .container-med, .container, .container-slim, .container-slimmer {
    max-width: 1050px;
  }
}
@media (min-width: 1400px) {
  .container, .container-wide, .container-med, .container, .container-slim {
    max-width: 1250px;
  }
}
@media (min-width: 1600px) {
  .container, .container-wide, .container-med, .container, .container-slim {
    max-width: 1450px;
  }
}
@media (min-width: 1800px) {
  .container, .container-wide, .container-med, .container {
    max-width: 1650px;
  }
}
@media (min-width: 2000px) {
  .container, .container-wide, .container-med, .container {
    max-width: 1850px;
  }
}











/* =================== PARALLAX CONTAINER ====================== */

.parallax-content {
    width: 100%;
}

/* Text Sections */
.text-section {
/*    padding: 100px 20px; */
    text-align: left;
    font-family: Arial, sans-serif;
}

/* Image Sections 
.image-section {
    position: relative;
    width: 100%;
    height: 80vh;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}*/

.image-section {
    position: relative;
    width: 100vw; /* Full viewport width */
    overflow: hidden; /* Ensures content outside the section is not visible */
}

.image-section img {
    width: 100vw; /* Always full viewport width */
    height: auto; /* Maintain aspect ratio */
    object-fit: cover; /* Ensures the image scales nicely */
    object-position: center; /* Centers the image vertically and horizontally */
}





/* =================== IMAGE OVERLAY ================= */

.image-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.image-container img {
    max-width: 100%;
    height: auto;
}

.image-container-h {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.image-container-h img {
    max-height: 100vh;
    max-width: 100%;
}

.text-overlay {
    position: absolute;
    text-align: center;
}
.top-left {
    top: 0;
    left: 0;
    text-align: left;
    transform: none;
    margin: 2vw 0 0 2vw !important;
}
.top-center {
    top: 0;
    left: 50%;
    text-align: center;
    transform: translateX(-50%);
    margin: 4vw 0 0 0 !important; 
}
.top-right {
    top: 0;
    right: 0;
    text-align: right;
    transform: none;
    margin: 2vw 2vw 0 0 !important; 
}
.center-left {
    top: 50%;
    left: 0;
    text-align: left;
    transform: translateY(-50%);
    margin: 0 0 0 2vw !important; 
}
.center-center {
    top: 50%;
    left: 50%;
    text-align: center;
    transform: translate(-50%, -50%);
    margin: 0 !important; 
}
.center-right {
    top: 50%;
    right: 0;
    text-align: right;
    transform: translateY(-50%);
    margin: 0 2vw 0 0 !important; 
}
.bottom-left {
    bottom: 0;
    left: 0;
    text-align: left;
    transform: none;
    margin: 0 0 2vw 2vw !important; 
}
.bottom-center {
    bottom: 0;
    left: 50%;
    text-align: center;
    transform: translateX(-50%);
    margin: 0 0 6vw 0 !important; 
}
.bottom-right {
    bottom: 0;
    right: 0;
    text-align: right;
    transform: none;
    margin: 0 2vw 2vw 0 !important; 
}

@media only screen and (max-width: 1600px) {
    .top-center {
        margin: 4vw 0 0 0 !important;
    }
    .bottom-center {
        margin: 0 0 4vw 0 !important;
    }
}
@media only screen and (max-width: 1024px) {
    .top-center {
        margin: 3vw 0 0 0 !important;
    }
    .bottom-center {
        margin: 0 0 5vw 0 !important;
    }
}
@media only screen and (max-width: 992px) {
    .top-center {
        margin: 6vw 0 0 0 !important;
    }
    .bottom-center {
        margin: 0 0 3vw 0 !important;
    }
}
@media only screen and (max-width: 768px) {
    .top-center {
        margin: 3vw 0 0 0 !important;
    }
    .bottom-center {
        margin: 0 0 0vw 0 !important; 
    }
}
@media only screen and (max-width: 640px) {
    .top-center {
        margin: 0vw 0 0 0 !important;
    }
    .bottom-center {
        margin: 0 0 0vw 0 !important;
    }
}
@media only screen and (max-width: 480px) {
    .top-center {
        margin: 7vw 0 0 0 !important;
    }
    .bottom-center {
        margin: 0 0 0vw 0 !important;
    }
}

@media (min-width: 992px) {
  .button-container-s {
    max-width: 800px; 
  }
}




/* ================ Dark Transparent Overlay ======================== */

.image-container-darken {
    position: relative;
    display: inline-block;
    padding-right: 0px !important;
    padding-left: 0px !important;
}

.image-container-darken img {
    display: block;
    width: 100%;
    height: auto;
}

.image-container-darken .overlay-darken {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, var(--grey-shade-decimal)); /* Ensure correct CSS property */
    pointer-events: none;
}






/* ======================== ROWS & COLUMNS ====================== */

.row {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}
.row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}

.col {
  flex: 1 0 0%;
}
.col-auto {
  flex: 0 0 auto;
  width: auto;
}
.col-1 {
  flex: 0 0 auto;
  width: 8.33333333%;
}
.col-2 {
  flex: 0 0 auto;
  width: 16.66666667%;
}
.col-3 {
  flex: 0 0 auto;
  width: 25%;
}
.col-4 {
  flex: 0 0 auto;
  width: 33.33333333%;
}
.col-5 {
  flex: 0 0 auto;
  width: 41.66666667%;
}
.col-6 {
  flex: 0 0 auto;
  width: 50%;
}
.col-7 {
  flex: 0 0 auto;
  width: 58.33333333%;
}
.col-8 {
  flex: 0 0 auto;
  width: 66.66666667%;
}
.col-9 {
  flex: 0 0 auto;
  width: 75%;
}
.col-10 {
  flex: 0 0 auto;
  width: 83.33333333%;
}
.col-11 {
  flex: 0 0 auto;
  width: 91.66666667%;
}
.col-12 {
  flex: 0 0 auto;
  width: 100%;
}
.offset-1 {
  margin-left: 8.33333333%;
}
.offset-2 {
  margin-left: 16.66666667%;
}
.offset-3 {
  margin-left: 25%;
}
.offset-4 {
  margin-left: 33.33333333%;
}
.offset-5 {
  margin-left: 41.66666667%;
}
.offset-6 {
  margin-left: 50%;
}
.offset-7 {
  margin-left: 58.33333333%;
}
.offset-8 {
  margin-left: 66.66666667%;
}
.offset-9 {
  margin-left: 75%;
}
.offset-10 {
  margin-left: 83.33333333%;
}
.offset-11 {
  margin-left: 91.66666667%;
}
.g-0 {
  --bs-gutter-x: 0;
}
.g-0 {
  --bs-gutter-y: 0;
}
.g-1 {
  --bs-gutter-x: 0.25rem;
}
.g-1 {
  --bs-gutter-y: 0.25rem;
}
.g-2 {
  --bs-gutter-x: 0.5rem;
}
.g-2 {
  --bs-gutter-y: 0.5rem;
}
.g-3 {
  --bs-gutter-x: 1rem;
}
.g-3 {
  --bs-gutter-y: 1rem;
}
.g-4 {
  --bs-gutter-x: 1.5rem;
}
.g-4 {
  --bs-gutter-y: 1.5rem;
}
.g-5 {
  --bs-gutter-x: 3rem;
}
.g-5 {
  --bs-gutter-y: 3rem;
}
@media (min-width: 576px) {
  .col-sm {
    flex: 1 0 0%;
  }
  .col-sm-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-sm-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-sm-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-sm-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-sm-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-sm-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-sm-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-sm-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-sm-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-sm-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-sm-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-sm-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-sm-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-sm-0 {
    margin-left: 0;
  }
  .offset-sm-1 {
    margin-left: 8.33333333%;
  }
  .offset-sm-2 {
    margin-left: 16.66666667%;
  }
  .offset-sm-3 {
    margin-left: 25%;
  }
  .offset-sm-4 {
    margin-left: 33.33333333%;
  }
  .offset-sm-5 {
    margin-left: 41.66666667%;
  }
  .offset-sm-6 {
    margin-left: 50%;
  }
  .offset-sm-7 {
    margin-left: 58.33333333%;
  }
  .offset-sm-8 {
    margin-left: 66.66666667%;
  }
  .offset-sm-9 {
    margin-left: 75%;
  }
  .offset-sm-10 {
    margin-left: 83.33333333%;
  }
  .offset-sm-11 {
    margin-left: 91.66666667%;
  }
  .g-sm-0 {
    --bs-gutter-x: 0;
  }
  .g-sm-0 {
    --bs-gutter-y: 0;
  }
  .g-sm-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-sm-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-sm-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-sm-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-sm-3 {
    --bs-gutter-x: 1rem;
  }
  .g-sm-3 {
    --bs-gutter-y: 1rem;
  }
  .g-sm-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-sm-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-sm-5 {
    --bs-gutter-x: 3rem;
  }
  .g-sm-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 768px) {
  .col-md {
    flex: 1 0 0%;
  }
  .col-md-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-md-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-md-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-md-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-md-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-md-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-md-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-md-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-md-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-md-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-md-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-md-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-md-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-md-0 {
    margin-left: 0;
  }
  .offset-md-1 {
    margin-left: 8.33333333%;
  }
  .offset-md-2 {
    margin-left: 16.66666667%;
  }
  .offset-md-3 {
    margin-left: 25%;
  }
  .offset-md-4 {
    margin-left: 33.33333333%;
  }
  .offset-md-5 {
    margin-left: 41.66666667%;
  }
  .offset-md-6 {
    margin-left: 50%;
  }
  .offset-md-7 {
    margin-left: 58.33333333%;
  }
  .offset-md-8 {
    margin-left: 66.66666667%;
  }
  .offset-md-9 {
    margin-left: 75%;
  }
  .offset-md-10 {
    margin-left: 83.33333333%;
  }
  .offset-md-11 {
    margin-left: 91.66666667%;
  }
  .g-md-0 {
    --bs-gutter-x: 0;
  }
  .g-md-0 {
    --bs-gutter-y: 0;
  }
  .g-md-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-md-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-md-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-md-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-md-3 {
    --bs-gutter-x: 1rem;
  }
  .g-md-3 {
    --bs-gutter-y: 1rem;
  }
  .g-md-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-md-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-md-5 {
    --bs-gutter-x: 3rem;
  }
  .g-md-5 {
    --bs-gutter-y: 3rem;
  }
}
 @media (min-width: 1025px) {
  .col-lg {
    flex: 1 0 0%;
  }
  .col-lg-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-lg-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-lg-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-lg-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-lg-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-lg-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-lg-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-lg-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-lg-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-lg-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-lg-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-lg-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-lg-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-lg-0 {
    margin-left: 0;
  }
  .offset-lg-1 {
    margin-left: 8.33333333%;
  }
  .offset-lg-2 {
    margin-left: 16.66666667%;
  }
  .offset-lg-3 {
    margin-left: 25%;
  }
  .offset-lg-4 {
    margin-left: 33.33333333%;
  }
  .offset-lg-5 {
    margin-left: 41.66666667%;
  }
  .offset-lg-6 {
    margin-left: 50%;
  }
  .offset-lg-7 {
    margin-left: 58.33333333%;
  }
  .offset-lg-8 {
    margin-left: 66.66666667%;
  }
  .offset-lg-9 {
    margin-left: 75%;
  }
  .offset-lg-10 {
    margin-left: 83.33333333%;
  }
  .offset-lg-11 {
    margin-left: 91.66666667%;
  }
  .g-lg-0 {
    --bs-gutter-x: 0;
  }
  .g-lg-0 {
    --bs-gutter-y: 0;
  }
  .g-lg-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-lg-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-lg-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-lg-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-lg-3 {
    --bs-gutter-x: 1rem;
  }
  .g-lg-3 {
    --bs-gutter-y: 1rem;
  }
  .g-lg-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-lg-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-lg-5 {
    --bs-gutter-x: 3rem;
  }
  .g-lg-5 {
    --bs-gutter-y: 3rem;
  }
}
 @media (min-width: 1400px) {
  .col-xl {
    flex: 1 0 0%;
  }
  .col-xl-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-xl-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-xl-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-xl-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-xl-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-xl-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-xl-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-xl-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-xl-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-xl-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-xl-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-xl-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-xl-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-xl-0 {
    margin-left: 0;
  }
  .offset-xl-1 {
    margin-left: 8.33333333%;
  }
  .offset-xl-2 {
    margin-left: 16.66666667%;
  }
  .offset-xl-3 {
    margin-left: 25%;
  }
  .offset-xl-4 {
    margin-left: 33.33333333%;
  }
  .offset-xl-5 {
    margin-left: 41.66666667%;
  }
  .offset-xl-6 {
    margin-left: 50%;
  }
  .offset-xl-7 {
    margin-left: 58.33333333%;
  }
  .offset-xl-8 {
    margin-left: 66.66666667%;
  }
  .offset-xl-9 {
    margin-left: 75%;
  }
  .offset-xl-10 {
    margin-left: 83.33333333%;
  }
  .offset-xl-11 {
    margin-left: 91.66666667%;
  }
  .g-xl-0 {
    --bs-gutter-x: 0;
  }
  .g-xl-0 {
    --bs-gutter-y: 0;
  }
  .g-xl-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-xl-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-xl-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-xl-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-xl-3 {
    --bs-gutter-x: 1rem;
  }
  .g-xl-3 {
    --bs-gutter-y: 1rem;
  }
  .g-xl-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-xl-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-xl-5 {
    --bs-gutter-x: 3rem;
  }
  .g-xl-5 {
    --bs-gutter-y: 3rem;
  }
}









/* =========== REVERSE COLUMNS ON MOBILE ======================== */

/* General Text Left Margin 
.text-left {
    margin-left: 2vw;
    margin-right: 2vw;
}*/

/* On Desktop (min-width: 1025px) */
@media only screen and (min-width: 1025px) {
  /* On desktop, no order change, columns remain as is */
  .reverse-columns-mobile .col-md-12 {
    order: initial; /* Default order */
  }
}

/* On Mobile (max-width: 1024px) */
@media only screen and (max-width: 1024px) {
  /* Apply reverse order on mobile */
  .reverse-columns-mobile .col-md-12:nth-child(1) {
    order: 2;  /* First column moves below */
  }

  .reverse-columns-mobile .col-md-12:nth-child(2) {
    order: 1;  /* Second column moves to the top */
  }

  /* Adjust text margins on mobile 
  .reverse-columns-mobile .text-left {
    margin-left: 3vw;
    margin-right: 3vw;
  }*/
}







/*================ LIST GROUP ===================== */


.list-group {
  display: flex;
  flex-direction: column;
  margin-bottom: 10px;
}


/* ================== TABLE ======================== */


dl {
  margin-top: 0;
  margin-bottom: 1rem;
}
dt {
  font-weight: 700;
}
dd {
  margin-bottom: 0.5rem;
  margin-left: 0;
}
table {
  caption-side: bottom;
  border-collapse: collapse;
}
th {
  text-align: inherit;
  text-align: -webkit-match-parent;
    font-weight: 300!important;
}
tbody,
td,
th,
thead,
tr {
  border-color: inherit;
  border-style: solid;
  border-width: 0;
}
.table {
  --bs-table-bg: transparent;
  --bs-table-accent-bg: transparent;
/*  --bs-table-striped-color: #212529;    */
  --bs-table-striped-bg: rgba(0, 0, 0, 0.05);
/*  --bs-table-active-color: #212529;          */
  --bs-table-active-bg: rgba(0, 0, 0, 0.1);
  --bs-table-hover-color: #212529;
  --bs-table-hover-bg: rgba(0, 0, 0, 0.075);
  width: 100%;
  margin-bottom: 1rem;
/*  color: #212529; */
  vertical-align: top;
  border-color: #dee2e6;
}
.table > :not(caption) > * > * {
  padding: 0.5rem 0.5rem;
  background-color: var(--bs-table-bg);
  border-bottom-width: 1px;
  box-shadow: inset 0 0 0 9999px var(--bs-table-accent-bg);
}
.table > tbody {
  vertical-align: inherit;
}
.table > thead {
  vertical-align: bottom;
}
.table > :not(:first-child) {
  border-top: 2px solid currentColor;
}
.table-sm > :not(caption) > * > * {
  padding: 0.25rem 0.25rem;
}
.table-active {
  --bs-table-accent-bg: var(--bs-table-active-bg);
/*  color: var(--bs-table-active-color); */
}
.table-hover > tbody > tr:hover > * {
  --bs-table-accent-bg: var(--bs-table-hover-bg);
/*  color: var(--bs-table-hover-color); */
}
.table-light {
  --bs-table-bg: #f8f9fa;
  --bs-table-striped-bg: #ecedee;
  --bs-table-striped-color: var(--body-text);
  --bs-table-active-bg: #dfe0e1;
  --bs-table-active-color: var(--body-text);
  --bs-table-hover-bg: #e5e6e7;
  --bs-table-hover-color: var(--body-text);
/*  color: var(--body-text); */
  border-color: #dfe0e1;
}
.table-dark {
  --bs-table-bg: #212529;
  --bs-table-striped-bg: #2c3034;
  --bs-table-striped-color: var(--page-bg);
  --bs-table-active-bg: #373b3e;
  --bs-table-active-color: var(--page-bg);
  --bs-table-hover-bg: #323539;
  --bs-table-hover-color: var(--page-bg);
/*  color: var(--page-bg); */
  border-color: #373b3e;
}
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
@media (max-width: 575.98px) {
  .table-responsive-sm {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 767.98px) {
  .table-responsive-md {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 991.98px) {
  .table-responsive-lg {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}













/* ======================= CAMERATA ========================= */

.user-box {
  position: fixed;
  padding: 0;
  margin: 0;
  color: var(--body-text);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); 
  text-align: center;
  z-index: 9999;
  box-sizing: border-box;
}

@media (max-width: 1024px) {
  .user-box {
    position: static;
    top: auto;
    right: auto;
    float: right;
    padding: 10px 0;
    margin: 0 0 0 auto;
    width: 100%;
    max-width: 180px;
    font-size: 14px;
    box-sizing: border-box;
  }
}

.user-dropdown {
  position: relative;
  display: inline-block;
  width: 100%;
  cursor: pointer;
}

.user-dropdown-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 0 10px;
  min-width: 100px;
  height: 100%;
  box-sizing: border-box;
}

.user-dropdown-toggle::after {
  content: "▾";
  font-size: 22px;
}

.user-dropdown-content {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%; /* Match .user-box width */
  background-color: var(--page-bg);
  padding: 0 10px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  box-sizing: border-box;
  z-index: 9999;
}

.user-dropdown-content a {
  display: block;
  padding: 6px 10px;
  margin: 8px 0;
  font-size: 14px !important;
  font-family: var(--font-regular) !important;
  color: var(--section-bg);
  text-decoration: none;
}

.user-dropdown-content a:hover {
  background-color: var(--active-menu-bg);
  color: var(--active-menu) !important;
}

input, select, textarea {
  display: block;
  width: 100%;
  padding: 5px 20px 10px 20px;
  border-radius: 100px;
  margin-top: 10px;
  border: 1px solid var(--panel-border);
  background: var(--page-bg);
  color: var(--semi-muted-text);
  font-family: var(--font-body) !important;
  font-size: var(--p3) !important;
  line-height: var(--p3l);
}
textarea {
    border-radius: 16px;
    min-height: 180px;
    resize: vertical;
    padding:16px 18px;
    line-height:1.6;
}
input:focus, textarea:focus{
      border-color: var(--panel-border);
      box-shadow: var(--shadow);
}
.tab {
    display: inline-block;
    padding: 10px 20px;
    cursor: pointer;
}
    
@media (max-width: 768px) {
    .tab {
        display: inline-block;
        padding: 5px 10px;
        cursor: pointer;
    }
}

.active-tab {
  background-color: var(--primary-brand);
  color: var(--button-text);
}

#signup-form {
    display: none; 
}

.form-grid {
  display: grid;
  grid-template-columns: 0.5fr 1fr;
  gap: 20px 30px;
  align-items: center;
}

@media (max-width: 768px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
}

.form-grid label { 
    display:block; 
    padding-top: 8px;
    font-size: var(--p3);
    line-height: var(--p3l);
    color: var(--highlight-text);
}
.form-grid input[type="text"],
.form-grid input[type="date"],
.form-grid input[type="email"],
.form-grid select,
.form-grid textarea { 
    width:100%; 
  font-size: var(--p3);
  line-height: var(--p3l);
}
@media (max-width:579px) {
    .form-grid { 
        grid-template-columns: 1fr; 
    }
}
.contact-grid{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px 30px;
    align-items: start;
}
@media (max-width:1024px){
    .contact-grid { 
        grid-template-columns: 1fr; 
        gap:28px; 
    }
}
.contact-grid label { 
    display:block; 
    padding-top: 8px;
    font-size: var(--p3);
    line-height: var(--p3l);
    color: var(--highlight-text);
}
.contact-grid input[type="text"],
.contact-grid input[type="date"],
.contact-grid input[type="email"],
.contact-grid select,
.contact-grid textarea { 
    width:100%; 
  font-size: var(--p3);
  line-height: var(--p3l);
}
@media (max-width:579px) {
    .contact-grid { 
        grid-template-columns: 1fr; 
    }
}
.form-full{ 
    grid-column: 1 / -1;
}
.notice {
    margin: 0 0 12px 0;
    font-size: var(--p3);
    color: var(--body-text);
}
.notice.error {
    color: var(--body-text);
}
.hidden-hp { 
    position:absolute !important; 
    left:-10000px !important; 
    width:1px !important; 
    height:1px !important;
    overflow:hidden !important;
}
.msg {
    margin-top: 12px; 
}
.small { 
    font-size:.92rem; 
    opacity:.85; 
}
.filter-bar { 
    display:flex; 
    gap:10px; 
    align-items:end; 
    flex-wrap:wrap; 
    margin-bottom: 16px; 
}
.filter-bar .field { 
    display:flex; 
    flex-direction:column; 
    width: 180px; 
}
.row-actions button { 
    margin-right: 8px; 
}

.dev-table { 
    width:100%; 
    border-collapse:collapse; 
}
.dev-table th, .dev-table td { 
    padding:10px; 
    text-align:left;
    border-bottom: 1px solid var(--page-bg);
    font-weight: 300!important;
    vertical-align:top; 
}
 .modal-backdrop { 
    position:fixed; 
    inset:0; 
    background:var(--backdrop); 
    display:none; 
    align-items:center; 
    justify-content:center; 
    z-index:1000; 
} 
.modal { 
    background:var(--highlight-bg); 
    border: 1px solid var(--primary-border); 
    color:var(--body-text); 
    max-width:900px; 
    width:calc(100% - 40px); 
    border-radius:8px; 
    padding:20px; 
    box-shadow:0 10px 40px rgba(0,0,0,.25); 
    max-height:90vh; 
    overflow:auto; 
}
.grid { 
    display:grid; 
    grid-template-columns: 0.3fr 1fr; 
    gap:10px 16px; 
}
@media (max-width:640px){ 
    .grid { 
        grid-template-columns:1fr; 
    } 
}
.toast { 
    margin-top: 8px; 
}

#profile-form .form-grid {
  display: grid;
  grid-template-columns: 200px 1fr;
  row-gap: 20px;
  column-gap: 20px;
  align-items: center;
}

@media (max-width: 600px) {
  #profile-form .form-grid {
    grid-template-columns: 1fr;
    row-gap: 8px; /* Reduce vertical gap between label and field */
  }

  #profile-form .form-grid label {
    margin-bottom: 0;
  }
}

#user-display {
    position: fixed;
    top: 15px;
    padding-top: 1px;
    left: 13vw;
    font-size: var(--p1)!important;
    line-height: var(--p1l);
    color: var(--highlight-text)!important;
    background: transparent;
    white-space: nowrap;
    z-index: 9999;
    opacity: 0;              /* currently hides the user's given_name  */
}

@media (max-width: 1024px) {
    #user-display {
        position: fixed;
        top: 24px;
        z-index: 9999!important;
    }
}

/* Session-expired modal (reuses your general modal look) */
.sess-modal-backdrop {
    position: fixed; inset:0; display:none;
    align-items:center; justify-content:center; z-index: 2000;
    background: rgba(0,0,0,.45);
}
.sess-modal {
    background: var(--page-bg); color: var(--body-text);
    max-width: 520px; width: calc(100% - 40px);
    border: 1px solid var(--primary-border);
    border-radius: 8px; padding: 20px; box-shadow: 0 10px 40px rgba(0,0,0,.25);
}

.tbl {
    width:100%;
    border-collapse:collapse
}
.tbl th,.tbl td {
    padding:10px;
    border-bottom:1px solid var(--grey-87);
    text-align:left;
    vertical-align:top;
}
.pager {
    display:flex;
    gap:10px;
    align-items:center;
    justify-content:space-between;
    margin-top:12px;
} 
.section-heading { 
    grid-column: 1 / -1; 
    font-weight:600; 
    margin-top:10px; 
    border-top:1px solid var(--primary-border); 
    padding-top:8px; 
} 

@media (min-width: 1025px) {
    .hide-on-desktop {
        display: none;
    }
}
.page-heading {
    padding-top: 20px; 
    opacity: 0.3; 
    max-height: 50vh; 
    width: auto;
}

.profile-gate-notice {
  margin: 1.5rem 0;
  padding: 1rem 1.25rem;
  border-left: 4px solid var(--primary-brand);
  background: var(--highlight-bg);
  font-size: var(--p2);
  line-height: var(--p2l);
}

/* ============================================================
   MODAL – DARK UI OVERRIDES (Camerata)
   ============================================================ */

.modal,
.dialog,
.modal-dialog {
  background: var(--bg-panel, #1f1f1f);
  color: var(--text-primary, #e6e6e6);
  border-radius: 14px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.6);
}

/* Modal body text */
.modal p,
.dialog p {
  font-size: var(--p1);
  line-height: 1.5;
  color: var(--text-primary, #e6e6e6);
}

/* Modal heading */
.modal h1,
.modal h2,
.dialog h1,
.dialog h2 {
  font-family: var(--font-brand);
  font-weight: 300;
  margin-bottom: 0.75rem;
}

/* Button row */
.modal-actions,
.dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 1rem;
  margin-top: 1.5rem;
}

/* Cancel button – make it readable */
.modal-actions .cancel,
.dialog-actions .cancel,
.modal button.cancel {
  font-size: var(--p2);
  color: var(--text-secondary, #bdbdbd);
  background: transparent;
  border: none;
  cursor: pointer;
}

/* Primary action already matches your system */
.modal-actions .primary,
.dialog-actions .primary {
  padding: 0.75rem 1.5rem;
}

/* ============================================================
   Gate notice of profile detail required
   ============================================================ */

.profile-gate-notice{
  margin: 0;
  padding: 12px 16px;
  background: var(--primary-highlight);
  color: var(--button-text);
  font-size: 24px;
  line-height: 1.35;
  margin-top: var(--menu-height);
  text-align: center;
}

.profile-gate-notice strong{
  color: var(--button-text);
}




/* ======================= LOGIN-NAV ========================= */

.userbox-wrapper {
  display: flex;
  align-items: left;
  justify-content: left; /* Ensures centering in menu */
  height: auto !important;
/*  padding: 0 10px; */
}

.menu-login-button {
  all: unset;
  display: inline-block;
  padding: 6px 20px !important;
  margin-top: 30px!important;
  font-size: var(--p2) !important;
  font-family: var(--font-body) !important;
  line-height: var(--p2l)!important;
/*  background: var(--primary-brand) !important;  Sets the background colour of the Login/Logout Button     */
  color: var(--button-text) !important;
  border-radius: 30px;
  cursor: pointer;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  transition: background 0.2s ease;
}


.menu-login-button:hover {
    background: var(--primary-brand);
    background: var(--primary-gradient);
    color: var(--button-text);
}

#user-box-container {
  height: auto !important;
}


@media (max-width: 1024px) {
    .desktop-nav {
        display: none;
    }
    
    .nav-logo-wrap.hide-on-mobile {
        display: none !important;
    }
    
    .nav-logo-wrap.show-on-mobile {
        display: block !important;
        text-align: center;
        padding: 10px 0;
    }
    
    .menu-login-button {
        display: inline-block;
        margin: 10px auto;
    }
    .userbox-wrapper {
        display: none;
    }
}

















/* ======================= NAV ========================= */

.nav {
  display: flex;
  flex-wrap: wrap;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}
.nav-link {
  display: block;
  text-decoration: none !important;
  transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out,
    border-color 0.2s ease-in-out;
}
.nav-link-footer {
  display: block;
  padding: 0 0 23px 0 !important;
  text-decoration: none;
}
.nav-link-footer:hover {
    color: var(--highlight-text)!important;
}
.footer-address {
  display: block;
  padding: 0 0 22px 0 !important;
  text-decoration: none;
  transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out,
    border-color 0.2s ease-in-out;
  color: var(--body-text);  
}
.footer-address hover {
  display: block;
  padding: 0 0 22px 0 !important;
  text-decoration: none;
  transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out,
    border-color 0.2s ease-in-out;
  color: var(--body-text);  
}
.map-link {
  color: var(--body-text);
  display: block;
  text-decoration: none;
  transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out,
    border-color 0.2s ease-in-out;
}
.map-link:focus,
.map-link:hover,
.map-link:active {
  color: var(--body-text);
  text-decoration: none !important;
}
/* Add a gradient background to the active tab */
.nav-tabs .nav-link.active {
  background: var(--gradient3);
  color: var(--body-text);
  font-family: var(--font-semibold);
  border: none;
  border-radius: 4px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.4); /* Add a subtle shadow */
  transition: all 0.2s ease-in-out; /* Smooth transition */
}
/* Add a hover effect to the tabs */
.nav-tabs .nav-link {
/*  color: #555; */
  transition: all 0.2s ease-in-out;
}
.nav-tabs .nav-link:hover {
  background-color: #f1f1f1;
  border-radius: 4px;
  text-shadow: 0px 1px 2px rgba(0, 0, 0, 0.2); /* Adds text shadow */
}
/* Add a subtle animation to tab transitions */
.nav-tabs .nav-link:not(.active) {
  font-family: var(--font-semibold);
  color: var(--body-text);
  border: none;
  border-radius: 8px;
  background-color: var(--section-bg);
  padding: 10px;
  margin: 0 5px;
}
/* Slightly increase spacing between tabs */
.nav-tabs {
  gap: 10px; /* Adds space between tabs */
  margin-bottom: 20px;
}
.nav-tabs .dropdown-menu {
  margin-top: -1px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.tab-content {
    height: auto !important;
    overflow: hidden;
}
.tab-content > .tab-pane {
    height: auto;
  display: none;
}
.tab-content > .active {
    height: auto;
  display: block;
}






/*  ==================  ACCORDION  ================== */


.menu-button {
  width: 100%;
  padding: 10px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--body-text);
  border-bottom-width: 1px;
  border-bottom-style: solid;
  border-bottom-color: inherit;
  border-top: none; 
  border-left: none; 
  border-right: none; 
  background: transparent;
  cursor: pointer;
}


.icon {
  font-size: 20px;
  transition: 0.2s;
}

.menu-button.open .icon {
  transform: rotate(45deg);
}

.content {
  padding: 0 20px;
  background: transparent;
  transition: 0.2s;
  height: 0;
  overflow: hidden;
}
 












/* =================== FOUR-ITEM CAROUSEL ====================== */

/* Style for each individual slide/item */
.multi-item-slider .item {
    padding: 0 25px; /* Creates a gap between slides */
}

.multi-item-slider .item img {
    width: 70%;
    height: auto;
    margin-bottom: 15px;
}

.multi-item-slider .item .caption {
    text-align: center;
}

/* Specific arrow styling for THIS slider to avoid conflicts */
.multi-item-slider .slick-prev,
.multi-item-slider .slick-next {
    width:  calc(32px + .75vw);
    height:  calc(32px + .75vw);
    background: transparent;
    box-shadow: 0 5px 7px 0 rgba(0, 0, 0, 0.3);  
    padding-right: 20px;
    border-radius: 50%;
    opacity: 0.4;
    z-index: 1;
}

.multi-item-slider .slick-prev:hover,
.multi-item-slider .slick-next:hover {
    width:  calc(32px + .75vw);
    height:  calc(32px + .75vw);
    opacity: 1;
    background-color: transparent;
}

/* Positioning for the arrows */
.multi-item-slider .slick-prev {
    left: -10px;
}
.multi-item-slider .slick-next {
    right: -10px;
}

/* This is how the arrow is hidden at the start/end */
.multi-item-slider .slick-arrow.slick-disabled {
    opacity: 0;
    cursor: default;
}

/* Hide the default theme's icon */
.multi-item-slider .slick-prev::before,
.multi-item-slider .slick-next::before {
    display: none;
}

/* Style for your Font Awesome icon inside the arrows */
.multi-item-slider .slick-prev i,
.multi-item-slider .slick-next i {
    font-size: calc(20px + 0.5vw);
    color: var(--highlight-text);
    line-height: calc(32px + .75vw);
    display: block;
    width: calc(32px + .75vw);
    text-align: center;
    background: transparent;
    border: 1px solid var(--highlight-text);
    border-radius: 50%;
}

.multi-item-slider .slick-prev i {
    padding-right: 2px;
}
.multi-item-slider .slick-next i {
    padding-left: 2px;
}












/* ========= TWO COLUMN SLIDER (DROP-IN) =========== */

/* Image slider is the positioning context for arrows */
.image-slider {
  position: relative;
}

.image-container img {
  width: 100%;
  height: auto;
}

@media (max-width: 1024px) {
  .image-container img {
    width: 80%;
    height: auto;
  }
}

/* Hide text slider controls (we won't use them) */
.text-slider .slick-dots,
.text-slider .slick-arrow {
  display: none !important;
}

/* ===========================
   ARROWS (IMAGE SLIDER)
   =========================== */
.image-slider .slick-prev,
.image-slider .slick-next {
  width:  calc(32px + .75vw);
  height: calc(32px + .75vw);

  background: transparent;
  border: 1px solid var(--highlight-text);
  border-radius: 50%;
  box-shadow: 0 5px 7px 0 rgba(0, 0, 0, 0.3);

  position: absolute;
  z-index: 2;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.4;
}

/* Hide default theme arrow icon */
.image-slider .slick-prev::before,
.image-slider .slick-next::before {
  display: none;
}

/* Font Awesome icon styling */
.image-slider .slick-prev i,
.image-slider .slick-next i {
  font-size: calc(20px + 0.5vw);
  color: var(--highlight-text);

  display: block;
  line-height: calc(32px + .75vw);
  text-align: center;
  width: 100%;
  opacity: 1;
}

.image-slider .slick-prev i { padding-right: 2px; }
.image-slider .slick-next i { padding-left: 2px; }

.image-slider .slick-prev:hover,
.image-slider .slick-next:hover {
  background: transparent;
  opacity: 1;
}

.image-slider .slick-prev:hover i,
.image-slider .slick-next:hover i {
  opacity: 1;
}

/* Position arrows on large screens — SCOPE to .image-slider to avoid theme collisions */
.image-slider .slick-prev {
  left: calc(0 - 32px - .75vw);
}
.image-slider .slick-next {
  right: calc(0 - 32px - .75vw);
}

/* Hide disabled arrow */
.image-slider .slick-arrow.slick-disabled {
  opacity: 0;
  cursor: default;
}

/* Responsive arrow positioning */
@media (max-width: 1024px) {
  .image-slider {
    margin-bottom: 20px;
  }
  .image-slider .slick-prev { left: 10px; }
  .image-slider .slick-next { right: 10px; }
}

/* Optional: global dots styling (if you use dots elsewhere) */
.slick-dots li button:before {
  color: var(--slick-dot);
  opacity: 1;
}
.slick-dots li.slick-active button:before {
  color: var(--slick-dot-active);
  opacity: 1;
}

/* ===========================
   TEXT PANEL (NOT A SLICK SLIDER)
   This avoids Slick fade + theme CSS conflicts.
   =========================== */

/* Ensure text column doesn't "collapse" */
#oladra-play .text-slider {
  position: relative;
}

/* Soft fade on text swap */
#oladra-play .text-slider .text-panel {
  transition: opacity 160ms ease;
}

#oladra-play .text-slider .text-panel.is-changing {
  opacity: 0.15;
}

/* Keep internal margins predictable */
#oladra-play .text-slider .text-content {
  margin: 0;
}

/* Prevent vertical wobble by stabilising the text panel */
#oladra-play .text-slider {
  display: flex;
  align-items: flex-start;
}

#oladra-play .text-slider .text-panel {
  min-height: 1px; /* will be set via JS */
}



/* ========= PRODUCT SLIDER 1 ============ */

/* Ensure the entire image container behaves correctly */
.image-container-s {
  position: relative; /* Ensure this parent container positions its children properly */
  text-align: center;
  width: 100%; /* Ensure it takes up full width of its container */
}

/* Image Wrapper */
.image-wrapper-s {
  position: relative; /* This positions the button container relative to the image */
  width: 100%; 
  padding-bottom: 60%; /* Aspect ratio for 2000x1200 images (60%) */
  height: 0; /* Needed to maintain aspect ratio */
  overflow: hidden; /* Prevents overflow */
}

/* Selected Image */
.selected-image-s {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover; /* Ensure the image covers the entire container */
  opacity: 0; /* Initially hidden */
  transition: opacity .2s ease;
  z-index: 1; /* Keeps images behind buttons */
}

.selected-image-s.show {
  opacity: 1; /* Visible when selected */
}

/* Button Container - must be relative to the image container */
.button-container-s {
  background: none; /* Use your desired gradient background */
  position: absolute;
  bottom: 10%; /* Position 20% from the bottom of the image */
  left: 50%; /* Center it horizontally */
  transform: translateX(-50%); /* Horizontal centering trick */
  /* display: flex; */
  justify-content: space-between;
  max-width: 800px; /* Limit max width to 800px */
  width: 100%; /* Full width for responsive design */
  /* padding: 1vw 5vw 1vw 5vw; /* Padding for button spacing */
  z-index: 10; /* Make sure the button container is above the images */
/*  border-radius: 10vw; /* Rounded corners */
}

/* Button Styling */
.button-s {
  background: none;
  font-family: var(--font-medium);
  font-size: calc(11px + 0.4vw);
  color: var(--slider-text);
  cursor: pointer;
  line-height: 1.5;
  border: none;
  outline: none;
  padding: 0.5vw 0.5vw 0.5vw 0.5vw;
  text-decoration: none;
}

.button-s:hover,
.button-s.active {
/*    background: var(--slider-active-bg); */
    color: var(--slider-active-text);
    border-radius: 10px;
    border: 1px solid var(--accent-80);
/*    box-shadow: 0 5px 7px 0 rgba(0, 0, 0, 0.4);  */
}

/* Adjust button container for smaller screens */
@media (max-width: 1024px) {
    .button-container-s {
        max-width: 90%; /* Make the button container full width on smaller screens */
/*    padding: 0.3vw 2vw 0.3vw 2vw; /* Increase padding for better visibility on smaller screens */
        bottom: 0; /* Position 20% from the bottom of the image */
  }
    .selected-image-s {
        position: absolute;
        top: -20px;
  }
}

/* --- Fix: force owl-item width to match its container --- */
.text-slider .owl-stage-outer,
.text-slider .owl-stage,
.text-slider .owl-item {
  width: 100% !important;
  max-width: 100% !important;
  flex: 1 1 100% !important;
  float: none !important;
}

/* Keep each text slide block-level and full-width */
.text-slider .owl-item > * {
  width: 100%;
  display: block;
}

/* Hide Owl’s built-in prev/next controls */
.text-slider .owl-nav,
.text-slider .owl-prev,
.text-slider .owl-next {
  display: none !important;
}











/* ========= PRODUCT SLIDER 2 ============ */

/* SLIDER CONTAINER */
.slider-container {
  position: relative;
  width: 100%;
  overflow: hidden;
}

/* SLIDER TRACK — important: match width of all slides */
.slider {
  display: flex;
  transition: transform 0.2s ease-in-out;
  width: auto; /* 100% * number of slides */
}

/* SLIDE — fix width to 100% of visible container */
.slide {
  width: 100%;
  flex-shrink: 0;
}

/* IMAGE — fill slide exactly */
.slide img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* NAV BUTTONS */
.nav-slider {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 2rem;
  background: rgba(0, 0, 0, 0.4);
  color: white;
  border: none;
  padding: 10px;
  cursor: pointer;
  z-index: 10;
}

.prev {
  left: 10px;
}

.next {
  right: 10px;
}


/* --------  Gradient Background ------------ */

.gradient-panel {
  width: 100%;
  height: auto; /* or whatever height you need */

  background-image:  url("/images/gradient3.jpg");

  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}






/*  ============ MAIN MENU ===============  */

.inner-nav.desktop-nav {
  display: flex;
  justify-content: space-around;
  align-items: center;
  gap: 2vw;
}
@media (max-width: 1024px) {
    .inner-nav.desktop-nav {
       gap: 0;
    }
}

.nav-left,
.nav-right {
  display: flex;
  gap: 30px;
}
@media (max-width: 1500px) {
    .nav-left,
    .nav-right {
      display: flex;
      gap: 10px;
    }
}
@media (max-width: 1024px) {
    .nav-left,
    .nav-right {
      display: flex;
      gap: 1px;
    }
}

.nav-left {
    margin-right: .1vw!important;
    margin-left: .1vw!important; /*Adjust to taste */
}
@media (max-width: 1024px) {
    .nav-left {
        margin-right: 0.5vw!important;
        margin-left: 0.5vw!important; /*Adjust to taste */
    }
}
.nav-right {
    margin-left: .1vw!important;
   margin-right: .1vw!important; /*Adjust to taste */
}
@media (max-width: 1024px) {
    .nav-right {
        margin-left: 0.5vw!important;
       margin-right: 0.5vw!important; /*Adjust to taste */
    }
}
.nav-logo-wrap {
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.nav-size {
    font-size: var(--p1);
}
@media (max-width: 1500px) {
    .nav-size {
        font-size: var(--p1);
    }
}
.nav-logo-wrap {
  float: left;
/*  margin-right: 28px; */
}
.nav-logo-wrap .logo {
  display: flex;
  align-items: center;
  max-width: 188px;
  -webkit-transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
}
.nav-logo-wrap .logo img {
  width: auto;
  max-height: 100%;
  padding-top: 5px;
}
.nav-logo-wrap .logo:after,
.nav-logo-wrap .logo:before {
  display: none;
}
.logo:hover,
a.logo:hover {
  font-size: 16px;
  font-weight: 400 !important;
  text-decoration: none;
  filter: var(--image-filter);
}
.pad-top {  /* Position Side Logo  */
    padding-top: 6px !important;
}
/*.pad-top-mobile {
    padding-top: 16px !important;
}*/
.main-nav {
  width: 100%;
  height: var(--menu-height) !important; /* sets height of menu before scroll */
  position: absolute;
  top: 0px;
  left: 0;
  text-align: left;
  background: transparent;
  z-index: 1030;
  -webkit-transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  border-bottom: 1px solid var(--primary-border);
}
@media screen and (max-width: 1024px) {
    .main-nav {
        top: 0px;
        background: var(--mob-bg-menu)!important;
    }
}


/* ============================================================
   ACCOUNT BAR
   ============================================================ */

.account-bar {
  width: 100%;
  background: transparent; /* subtle */
  padding: 6px 0;          /* slim */
}

.account-bar.hidden {
  display: none;
}

.account-bar .full-wrapper {
  display: flex;
  justify-content: flex-end;
}

.account-bar-inner {
  position: relative;
  display: inline-block;
}

.account-username {
  cursor: pointer;
  font-size: var(--p1);
  color: var(--highlight-text);
  opacity: 1;
}

.account-username:hover {
  opacity: 1;
}

/* Dropdown */
.account-dropdown {
  position: absolute;
  right: 0;
  top: 26px;
  background: var(--black-90);
  padding: 10px 14px;
  border-radius: 10px;
  min-width: 160px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.35);
}

.account-dropdown.hidden {
  display: none;
}

.account-dropdown a {
  display: block;
  padding: 6px 0;
  color: var(--highlight-text);
  font-size: var(--p2);
  text-decoration: none;
}

.account-dropdown a:hover {
  opacity: 0.85;
}











/* === MOBILE MENU (shown at 1024px and below) === */
@media (max-width: 1024px) {
    /* Ensure hamburger is visible and clickable */
    .mobile-menu-toggle svg {
      top: 20px;
      width: 36px;
      height: 36px;
      stroke: var(--heading-text); /* Or a fixed color like black if needed */
      display: block;
    }
    
    .mobile-menu-toggle {
      width: 36px;
      height: 36px;
    }
  .mobile-top-bar {
    display: none;
    justify-content: space-between;
    align-items: center;
    padding: 8px 16px;
/*    background-color: var(--bg-menu); */
    position: relative;
    z-index: 9999;
    height: 60px;
  }

  .mobile-menu-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex: 0 0 auto;
    margin-top: 10px;
  }

  .mobile-logo {
    flex: 1 1 auto;
    text-align: center;
    margin-top: -20px;
  }

  .mobile-logo img {
    max-height: 30px;
    height: auto;
    width: auto;
    margin-right: 50px;
  }

  .mobile-login {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    margin-top: -40px;
  }

  .mobile-login a {
    display: inline-block;
    padding: 10px 22px;
    font-size: var(--p2);
/*    background-color: var(--primary-brand); */
    color: var(--button-text);
/*    border-radius: 30px; */
    text-decoration: none;
    white-space: nowrap;
    margin-top: 132px;
  }

  .mobile-login a:hover {
    display: inline-block;
    padding: 10px 22px;
    font-size: var(--p2);
/*    background-color: var(--primary-brand);  */
    color: var(--button-hover-text)!important;
/*    border-radius: 30px;  */
    text-decoration: none;
    white-space: nowrap;
  }

  .desktop-nav {
    display: none !important;
  }

}






/* === DESKTOP NAVIGATION (shown at 1025px and up) === */
@media (min-width: 1025px) {
  .mobile-top-bar {
    display: none !important;
  }

  .desktop-nav {
    display: flex !important;
  }

  .mobile-login a {
    all: unset;
  }
}

/* Base z-index for the toggle */
[data-theme-toggle] {
  z-index: 10;
}

/* Hide the toggle entirely while the mobile menu is open 
.mm-open [data-theme-toggle] {
  opacity: 0!important;
  pointer-events: none;
}*/





/* =========================================================
   MOBILE NAV — final overrides (drop-in)
   ========================================================= */
@media (max-width: 1024px) {
  /* Top bar row (hamburger / logo / login) */
  .mobile-top-bar {
    position: relative;      /* establish context for absolute children */
    z-index: 1000;           /* above page content */
  }

  /* Dropdown wrapper (the mobile menu list) */
  .mobile-nav-wrapper {
    /* Ensure our block wins over earlier styles */
    display: none !important;
    flex-direction: column;
    width: 100%;
    padding: 20px 0;
    background-color: var(--bg-menu);

    /* KEY: create a stacking context and put it above chip/toggle */
    position: relative;
    z-index: 3000;
  }
  .mobile-nav-wrapper.menu-open {
    display: flex !important;
  }

  /* List layout inside the dropdown */
  .mobile-nav-wrapper ul {
    flex-direction: column;
    width: 100%;
    text-align: left;
    padding: 0;
    margin: 0;
    list-style: none;
  }
  .mobile-nav-wrapper li {
    width: 100%;
    margin: 5px 0;
  }
  .mobile-nav-wrapper a {
    display: block;
    font-size: var(--p1);
    height: auto !important;
    line-height: 1.4 !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
    margin: 0 !important;
  }

  /* Desktop logo never shows on mobile */
  .nav-logo-wrap.hide-on-mobile { display: none !important; }
  .nav-logo-wrap.show-on-mobile {
    display: block !important;
    text-align: center;
    padding: 10px 0;
  }

  /* Button spacing inside dropdown */
  .menu-login-button {
    display: inline-block;
    margin: 10px auto;
  }

  /* --- Stacking fixes (this is what stops overlap) --- */

  /* Lower the fixed "User: ..." chip under the dropdown 
  #user-display {
    z-index: 20 !important;
  }*/

  /* Lower the MOBILE theme toggle under the dropdown.
     (Desktop toggle not affected.) */
  .show-on-mobile[data-theme-toggle] {
    position: absolute;  /* you already position it in top.php */
    z-index: 15 !important;
  }
}

#no-hand {
/*  cursor: default !important; */
}
.small-height {
  height: var(--menu-height) !important; /* sets height after scroll */
  top: 0;
  background: var(--bg-menu) !important; /* sets background-color after scroll */                              /* background */
  border-bottom: 1px solid var(--primary-border);
  opacity: var(--menu-opacity-on-scroll);
}
.small-height .mn-sub {
  margin-top: 0;
}
.inner-nav {
  position: relative;
  display: flex;
  justify-content: center;
}
.inner-nav ul {
/*  float: right; */
  margin: auto; 
/*  font-size: 10px; */
  font-family: var(--font-global);
  font-weight: 300;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 1.3;
}
@media (max-width: 1600px) {
    .inner-nav ul {
        letter-spacing: 0.01em;
    }
}
.inner-nav ul li {
  float: left;
  margin-left: var(--menuitem-spacing);
  position: relative;
}
.inner-nav ul li a {
  color: var(--heading-text);
  display: inline;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  text-decoration: none;
  padding: 0 var(--menuitem-padding-sides) 0 var(--menuitem-padding-sides);
  -webkit-transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  margin-top: 3px;
}
.inner-nav ul li:hover > a,
.inner-nav ul li a.active,
.inner-nav ul li a:hover {
  color: var(--highlight-text)!important;
  background: var(--active-menu-bg);
  opacity: 1;
  padding: 0 var(--menuitem-padding-sides) 0 var(--menuitem-padding-sides);
  text-decoration: none !important;
}
.mn-has-sub {
  font-weight: 400;
}
.mn-has-sub a:hover, 
.mn-has-sub a:active{
}
.mn-has-sub-icon {
  display: inline-block;
  width: 9px;
  height: 5px;
  position: relative;
  top: -0.18em;
  opacity: 0.9;
/*  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="9px" height="9px"><path fill-rule="evenodd" fill="rgb(0, 0, 0)" d="M8.886,0.631 L8.336,0.117 C8.263,0.049 8.178,0.015 8.083,0.015 C7.988,0.015 7.903,0.049 7.830,0.117 L4.506,3.155 L1.183,0.117 C1.109,0.049 1.025,0.015 0.930,0.015 C0.834,0.015 0.750,0.049 0.677,0.117 L0.127,0.631 C0.053,0.699 0.017,0.778 0.017,0.867 C0.017,0.956 0.053,1.035 0.127,1.103 L4.253,4.892 C4.327,4.960 4.411,4.994 4.506,4.994 C4.602,4.994 4.686,4.960 4.759,4.892 L8.886,1.103 C8.959,1.035 8.996,0.956 8.996,0.867 C8.996,0.778 8.959,0.699 8.886,0.631 L8.886,0.631 Z"/></svg>');

  background: var(--arrow-color);  
  -webkit-transition: all 0.27s cubic-bezier(0, 0, 0.58, 1);
  transition: all 0.27s cubic-bezier(0, 0, 0.58, 1);*/
}
.mobile-login a:hover {
  color: var(--button-hover-text)!important;
}






/*   =========================  MOBILE MENU  =======================  */

.mobile-on .inner-nav ul li .mn-has-sub-icon {
  background-repeat: no-repeat!important;
  background-size: contain!important; /* Ensures it scales inside the container */
  background-position: center!important; /* Center the SVG */

  box-sizing: content-box; /* Ensure padding is outside the container */
    
}
.mobile-on .inner-nav ul li a.active .mn-has-sub-icon, 
.mobile-on .inner-nav ul li a:hover .mn-has-sub-icon {
/*  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="9px" height="9px"><path fill-rule="evenodd" fill="rgb(255, 255, 255)" d="M8.886,0.631 L8.336,0.117 C8.263,0.049 8.178,0.015 8.083,0.015 C7.988,0.015 7.903,0.049 7.830,0.117 L4.506,3.155 L1.183,0.117 C1.109,0.049 1.025,0.015 0.930,0.015 C0.834,0.015 0.750,0.049 0.677,0.117 L0.127,0.631 C0.053,0.699 0.017,0.778 0.017,0.867 C0.017,0.956 0.053,1.035 0.127,1.103 L4.253,4.892 C4.327,4.960 4.411,4.994 4.506,4.994 C4.602,4.994 4.686,4.960 4.759,4.892 L8.886,1.103 C8.959,1.035 8.996,0.956 8.996,0.867 C8.996,0.778 8.959,0.699 8.886,0.631 L8.886,0.631 Z"/></svg>')!important;
*/
  background: var(--mob-active-arrow);  
  background-repeat: no-repeat!important;
  background-size: contain!important; /* Ensures it scales inside the container */
  background-position: center!important; /* Center the SVG */
  box-sizing: content-box; /* Ensure padding is outside the container */
  
  -webkit-transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
}
.mn-has-sub-icon-right {
  display: inline-block;
  width: 5px;
  height: 9px;
  position: relative;
  top: 0.3em;
  opacity: 0.9;
/*  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="9px" height="9px"><path fill-rule="evenodd" fill="rgb(0, 0, 0)" d="M8.886,0.631 L8.336,0.117 C8.263,0.049 8.178,0.015 8.083,0.015 C7.988,0.015 7.903,0.049 7.830,0.117 L4.506,3.155 L1.183,0.117 C1.109,0.049 1.025,0.015 0.930,0.015 C0.834,0.015 0.750,0.049 0.677,0.117 L0.127,0.631 C0.053,0.699 0.017,0.778 0.017,0.867 C0.017,0.956 0.053,1.035 0.127,1.103 L4.253,4.892 C4.327,4.960 4.411,4.994 4.506,4.994 C4.602,4.994 4.686,4.960 4.759,4.892 L8.886,1.103 C8.959,1.035 8.996,0.956 8.996,0.867 C8.996,0.778 8.959,0.699 8.886,0.631 L8.886,0.631 Z"/></svg>');
*/
  background: var(--mob-inactive-arrow); 
}






/*  ==================  SUB MENUS  ==================  */

.mn-sub-trans {
    display: none;
    max-height: 80vh;
    position: fixed;
    top: var(--menu-height);
    left: 0;
    padding: 10px;
    border-radius: 0 0 3px 3px;
  box-shadow: 0 6px 6px 0 rgba(0,0,0,0.05);
}
.inner-nav .mn-sub .mn-sub,
.mn-has-multi a {
  border-radius: 3px;
}
.mn-sub li {
  display: block;
  width: 100%;
  margin: 0 !important;
}
@media (min-width: 1025px) { 
    .narrow-menu {
        max-width: var(--sub-width)!important;
    }
}
.inner-nav ul li .mn-sub li a {
  display: block;
  color: var(--txt-sub);
  width: 100%;
  height: auto !important;
  line-height: 1.3 !important;
  position: relative;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 8px 12px;
  font-weight: 400!important;
  text-align: left;
  text-transform: none;
  border-left: none;
  border-right: none;
  letter-spacing: 0em;
  outline-offset: -2px !important;
  cursor: pointer;
  -webkit-transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
}












/*  ====================  MOBILE SUB-MENU  =========================  */

.mobile-on .mn-has-multi > li:last-child > a {
  border-bottom: 1px solid var(--page-bg) !important;
}
.inner-nav ul li .mn-sub li a:hover,
.mn-sub li a.active,
.mn-sub li a:hover {
  color: var(--button-hover-text)!important;                               /* color of hover and active submenu item */
  background: var(--active-sub-bg)!important;                       /* background colour of hover and active submenu item */
  text-decoration: none !important;
  border-radius: 0px;
}


.mn-sub li ul {
  left: 100%;
  right: auto;
  top: 0;
  border-left: 1px solid rgba(255, 255, 255, 0.07);
}
/* Fix last menu item dropdown alignment */
.inner-nav > ul > li:last-child .mn-sub {
  left: auto !important;
  right: auto !important;
}

/* Fix nested submenus under the last item */
.inner-nav > ul > li:last-child .mn-sub li ul {
  left: 100% !important;
  right: auto !important;
  top: 0;
  border-left: 1px solid rgba(255, 255, 255, 0.07);
  border-right: none;
}
.mobile-on .inner-nav li:last-child .mn-sub li ul {
  left: auto;
  right: auto;
  top: 0;
}
.mn-wrap {
  padding: 8px;
}
.mn-has-multi {
    width: 41vw;
    overflow: auto;
    padding: 10px;
    margin: 0 30vw 0 29vw !important;
    text-align: left;
    white-space: nowrap;
    border: 1px solid var(--body-text);
}
.slim {
    width: 22vw !important;
}
.mn-sub-multi {
/*    width: 100vw !important; */  /*  TEMP??????????????? */
    min-width: 20vw !important;
    max-width: 38vw !important;
    overflow: hidden;
    white-space: normal;
    float: none !important;
    display: inline-block !important;
    vertical-align: top;
}
.cols1 {
    width: 180px !important;
}
.mobile-on .rows1 {
    width: 20vw !important;
    margin: 0 !important;
    height: 140px !important;
    overflow: hidden !important;
}
.rows1 {
    width: 20vw !important;
    margin: 0 55vw 0 25vw !important;
    height: 160px !important;
    overflow: hidden !important;
/*    box-shadow: 0 3px 15px 0 rgba(0, 0, 0, 0.05); */
  box-shadow: 0 6px 6px 0 rgba(0,0,0,0.05);
}
.rows2 {
    width: 20vw !important;
    margin: 0 40vw 0 40vw !important;
    height: 160px !important;
    overflow: hidden !important;
/*    box-shadow: 0 3px 15px 0 rgba(0, 0, 0, 0.05); */
  box-shadow: 0 6px 6px 0 rgba(0,0,0,0.05);
}
.rows3 {
    width: 20vw !important;
    margin: 0 35vw 0 45vw !important;
    height: 160px !important;
    overflow: hidden !important;
/*    box-shadow: 0 3px 15px 0 rgba(0, 0, 0, 0.05); */
  box-shadow: 0 6px 6px 0 rgba(0,0,0,0.05);
}
.rows4 {
    width: 20vw !important;
    margin: 0 28vw 0 52vw !important;
    height: 160px !important;
    overflow: hidden !important;
/*    box-shadow: 0 3px 15px 0 rgba(0, 0, 0, 0.05); */
  box-shadow: 0 6px 6px 0 rgba(0,0,0,0.05);
}


.mobile-on .rows1,
.mobile-on .rows2,
.mobile-on .rows3,
.mobile-on .rows4 {
    width: 100vw !important;
    margin: 0 0 0 0 !important;
}
.cols4 {
    width: 180px !important;
}
.rows41 {
    width: 60vw !important;
    margin: 0 20vw 0 20vw !important;
    height: 200px !important;
    overflow: hidden !important;
}
.mn-sub-multi > ul {
  width: auto;
  margin: 0;
  padding: 0;
  float: none;
}
.mn-group-title {
  font-family: var(--font-global-bold);
  font-size: calc(13px + 0.05vw) !important;
  text-transform: uppercase;
  float: left;
  padding: 10px;
  cursor: default;
}
.mn-group-title li a:hover {
  cursor: default;
}
.mobile-on .mn-sub-multi > ul {
  left: auto;
  right: auto;
  border: none;
}
.mobile-on .mn-sub-multi {
    max-width: 98vw !important;
    display: block;
    width: 100% !important;
}
.mobile-on .mn-sub-multi > ul > li:last-child > a {
  border: none !important;
}
.mobile-on .mn-sub:not(.mn-has-multi) > li:last-child > a {
  border: none !important;
}
.mobile-on .mn-sub-multi:last-child > ul {
  border-bottom: none !important;
}
.mobile-on .desktop-nav {
  display: none;
  width: 100%;
  position: absolute;
  top: calc(var(--menu-height) - 2px);
  left: 0;
  padding: 0 15px;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.1);
}
.mobile-on .full-wrapper .desktop-nav {
  padding: 0;
}
.mobile-on .desktop-nav ul {
  width: 100%;
  float: none;
  background: var(--mob-bg-menu); 
  position: relative;
  margin-left: 1px!important;
  overflow-x: hidden;
}
.mobile-on .desktop-nav > ul {
  overflow-y: auto;
}
.mobile-on .desktop-nav ul li {
  display: block;
  float: none !important;
  overflow: hidden;
  background-color: var(--mob-bg-menu); 
}
.mobile-on .desktop-nav ul li ul {
  padding: 0;
}
.mobile-on .desktop-nav ul li a {
  display: block;
/*  width: 100%;
  height: 58px !important;
  line-height: 58px !important; */
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 20px;
  text-align: right;
  border-left: none;
  border-right: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.065);
  color: var(--mob-txt-menu);
  cursor: pointer;
  background: var(--mob-bg-menu);
}
.mobile-on .desktop-nav ul li a.active,
.mobile-on .desktop-nav ul li a:hover {
/*  background: var(--mob-active-bg)!important;     Sets the background colour of the active mobile menu item */
  color: var(--button-text)!important;
}
.mobile-on .desktop-nav ul li a:focus {
  outline-offset: -2px !important;
}
.mobile-on .mn-has-sub > .mn-has-sub-icon {
  display: block;
  width: 14px;
  height: 14px;
  font-size: 16px;
  line-height: 18px;
  position: absolute;
  top: 50%;
  right: 15px;
  margin-top: -8px;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background-repeat: no-repeat;
  background-size: 9px 5px;
  background-position: 50% 60%;
/*  background-image: url(data:image/svg+xml;utf8,SVG_REPLACED); 
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;*/
}
.mobile-on .mn-has-sub > .mn-has-sub-icon-right {
  display: block;
  width: 19px;
  height: 19px;
  font-size: 16px;
  line-height: 18px;
  position: absolute;
  top: 50%;
  right: 5px;
  margin-top: -8px;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background-repeat: no-repeat;
  background-size: 5px 9px;
  background-position: 60% 50%;
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  transform: rotate(90deg);
  border-radius: 50%;
}
.mobile-on .js-opened > .mn-has-sub > .mn-has-sub-icon {
  -webkit-transform: rotate(180deg);
  -moz-transform: rotate(180deg);
  transform: rotate(180deg);
}
.mobile-on .js-opened > .mn-has-sub > .mn-has-sub-icon-right {
  border-color: rgba(0, 0, 0, 0.4);
  -webkit-transform: rotate(270deg);
  -moz-transform: rotate(270deg);
  transform: rotate(270deg);
}
.mobile-on .inner-nav li {
  margin: 0 !important;
}
.mobile-on .mn-sub {
  display: none;
  opacity: 0;
  position: relative;
  left: 1px !important;
  right: 0;
  top: 0;
  bottom: 0;
  border-left: none !important;
  border-right: none !important;
  border-top: none;
  z-index: 101;
}
.mobile-on .mn-sub li {
  padding-left: 10px;
}
.inner-nav li.js-opened .mn-sub {
  opacity: 1;
}
.mobile-nav {
  display: none;
  float: right;
  padding-left: 15px;
  padding-right: 15px;
  vertical-align: middle;
  font-size: 16px;
  font-weight: 400;
  text-transform: uppercase;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -o-user-select: none;
  user-select: none;
  -webkit-transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  -webkit-transition-property: background, color, height;
  transition-property: background, color, height;
}
.mobile-nav.active,
.mobile-nav:hover {
  opacity: 0.75;
}
.mobile-nav:active {
  box-shadow: 0 0 35px rgba(0, 0, 0, 0.05) inset;
}
.mobile-on .mobile-nav {
  display: table;
}
.mobile-nav .fa {
  height: 100%;
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  font-size: 24px;
}
.mobile-on .mn-has-multi {
  min-width: 80vw;
  padding: 0;
  text-align: left;
  white-space: pre-line;
  margin: 0 1vw 0 1vw !important;
}
.mobile-on .mn-sub {
  width: 100% !important;
  height: auto !important;
  float: none;
  position: relative;
  overflow-x: hidden;
}
.mobile-on .mn-group-title {
  font-family: var(--font-global-bold);
  font-size: calc(10px + 0.15vw) !important;
}
.logo-accent {
  display: inline-block;
}











/* ========== MEGA MENU ================ */

/* Style for the dropdown list */
.mn-sub {
    position: absolute;
    top: 100%; /* Adjust based on your design */
    display: none; /* Hidden by default */
    list-style: none;
    padding: 0;
    margin: 0;
}
@media (min-width: 1025px) {
  .dropdown-item:hover .mn-sub {
    display: block; /* Show the dropdown on hover */
  }

  /* Show image container and fade in image when hovering over dropdown */
  .dropdown-item:hover .dropdown-image-container {
    visibility: visible; /* Ensure visibility */
    opacity: 1; /* Fully visible */
  }
}

/* Ensure the dropdown image container is on top of other elements */
.dropdown-image-container {
    position: absolute;
    top: 0;
    left: 50vw; /* Place it in the right half of the viewport */
    width: 50vw; /* Image container takes half of the viewport width */
    height: 35vw; /* Set the height proportional to the width for aspect ratio */
    visibility: visible;
    opacity: 1;
    z-index: 9999;
    overflow: hidden;
    display: flex;
    align-items: center; /* Vertically center the image */
    justify-content: center; /* Horizontally center the image */
}

/* Ensure the image fills the container proportionally */
.dropdown-image-container img {
    width: 100%; /* Scale the image to fill the width */
    height: auto; /* Automatically adjust the height */
    object-fit: cover; /* Cover the container with the image without distortion */
    object-position: center; /* Ensure the middle of the image is shown */
    transition: opacity 0.2s ease-in-out;
}

/* Ensure the dropdown container displays columns side by side */
.mn-sub {
    display: none;
    justify-content: space-between;
    padding: 10px;
    position: fixed;
    top: var(--menu-height);
    border-radius: 0 0 3px 3px;
    align-items: stretch;
    box-shadow: 0 3px 15px 0 rgba(0, 0, 0, 0.5);
}

/* Hide images when the screen width is below 1024px */
@media (max-width: 1024px) {
    .dropdown-image-container {
        display: none !important;
    }
}

.user-dropdown-toggle::after {
  content: none;
}


/*  Multi-Column Dropdown Menu Code  */

/* Ensure the dropdown container displays columns side by side */
.mn-sub {
    display: none;
    justify-content: space-between;
    padding: 10px;
    margin: 0;
    position: fixed;
    top: var(--menu-height);
    background: var(--page-contrast);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(5px);
    color: var(--active-menu);
    border-radius: 5px;
    align-items: stretch;
    box-shadow: 0 3px 15px 0 rgba(0, 0, 0, 0.1);
}
@media (max-width: 1024px) {
    .mn-sub {
        box-shadow: none;
        min-height: none;
        margin: 0 0 0 11px;
    }
}
/* Flexbox for dropdown columns */
.mn-sub .row {
    display: flex;
    justify-content: flex-start;
    width: 100%;
    align-items: stretch;
    gap: 0; /* Ensure no gap between the columns */
}
/* Adjust column widths */
.col-lg-2 .nogap {
    flex: 0 0 16.66%;
    padding: 0;
    margin: 0;
}
.col-lg-6 .nogap {
    flex: 0 0 50%;
    padding: 0;
    margin: 0;
}
.col-lg-2 .withgap {
    flex: 0 0 16.66%;
    padding: 5px;
    margin: 5px;
}
.col-lg-6 .withgap {
    flex: 0 0 50%;
    padding: 5px;
    margin: 5px;
}
/* Dropdown links in the first column */
.dropdown-links {
    list-style: none;
    padding: 0;
    margin: 0;
}
/* Links within the dropdown */
.dropdown-links li {
    margin-bottom: 5px;
}
.dropdown-links li a {
    text-decoration: none;
    padding: 0;
    margin: 0;
    text-align: left;
    display: block;
    width: 100%;
}
.dropdown-links ul li .mn-sub li a:hover,
.mn-sub li a.active,
.mn-sub li a:hover {
  text-decoration: none !important;
}
.dropdown-links ul li .mn-has-sub li a:hover,
.mn-has-sub li a.active,
.mn-has-sub li a:hover {
  text-decoration: none !important;
}
/* Responsive handling for smaller screens */
@media (max-width: 800px) {
    .mn-sub {
        flex-direction: column;
    }

    .dropdown-column {
        margin-bottom: 20px;
    }
}
/* Style for the image in the fourth column */
.static-content img {
    width: 100%;
    height: auto;
    transition: opacity 0.2s ease-in-out;
}
/* Remove the gap between columns */
.col-lg-2 {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    text-align: left;
    padding: 0;
    margin: 0;
}
/* Remove any extra padding or margin from the list */
.dropdown-links li {
    padding: 0;
    margin: 0;
}
/* Ensure that links are aligned to the left without any unwanted indentation */
.dropdown-links li a {
    padding: 0;
    margin: 0;
    text-align: left;
    display: block;
    width: 100%;
}








/*  =================  FOOTER  ======================  */

footer ul li a {
  text-decoration: none;
  text-transform: none;
  position: relative;
  display: block;
}
.footer ul li a:hover,
 .footer li a.active,
 .footer li a:hover {
  color: var(--highlight-text)!important;                          /* color of active submenu item */
  text-decoration: none !important;
}
.footer-list {
    text-align: left;
    color: var(--body-text);
}
@media (max-width: 767px) {
  .footer-list {
    text-align: center;
    margin-top: 20px;
  }
}
.footer-left {
  text-align: left !important;
}
.footer-right {
  text-align: right !important;
}
@media (max-width: 1024px) {
    .footer-left {
        text-align: center !important;
    }
    .footer-right {
        text-align: center !important;
    }
}


/* =============== CALL TO ACTION =================== */

.cta-panel {
    position: absolute; 
    top: 50%; 
    left: 50%;
    padding: 10px;
    opacity: 1;
    transform: translate(-50%, -50%); 
    width: calc(230px + 23vw); /* Set the panel's width smaller than the image */
    background: hsla(200, 20%, 100%, 0.1);
    border-radius: 16px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(5px);
    border: 1px solid hsla(200, 20%, 100%, 0.2);
     z-index: 2;
}
.cta-image {
    width: 100vw;
    height: auto;
    object-fit: cover;
}
@media (max-width: 767px) {
    .cta-image {
        min-height: 280px !important; /* Minimum height */
        object-fit: cover; /* Ensures the image covers the div, cropping if necessary */
        object-position: center; /* Align the image to the top so it truncates from the bottom */
    }
}
@media (min-width: 768px) {
    .cta-image {
        max-height: 600px !important; /* Limit the height */
        object-fit: cover; /* Ensures the image covers the container */
        object-position: center; /* Align the image to the top so it truncates from the bottom */
    }
}
.cta-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.0);
    opacity: 1!important;
    z-index: 1;
}



/*  =====================  FILTER DIVs  ======================== */

.bg-filter {
    background-color: var(--filter-bg);
}
.works-filter {
  list-style: none;
  padding: 0;
  margin: 0 0 60px 0;
  font-size: 15px;
  font-weight: 400;
  text-transform: uppercase;
  text-align: center;
  letter-spacing: 0.07em;
  cursor: default;
}
.works-filter a {
  display: inline-block;
  position: relative;
  margin: 0 27px;
  padding-bottom: 2px;
  text-decoration: none;
  -webkit-transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  transition: all 0.2s cubic-bezier(0, 0, 0.58, 1);
  cursor: pointer;
  color: var(--filter-head);
}
.works-filter a.active:hover {
  text-decoration: none !important;
}
.works-filter a:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 1px;
  background-color: var(--filter-head);
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: right center;
  transform-origin: right center;
  -webkit-transition: transform 0.2s ease-out;
  transition: transform 0.2s ease-out;
}
.works-filter a.active:after {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}
.works-filter a:hover:after {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: left center;
  transform-origin: left center;
}
.light-content .works-filter a {
  opacity: 0.72;
}
.light-content .works-filter a.active,
.light-content .works-filter a:hover {
/*  color: var(--page-bg);  */
  opacity: 1;
}
.light-content .works-filter a:after {
/*  background-color: var(--page-bg); */
}
.works-grid {
  list-style: none;
  margin: 0;
  padding: 0;
}
.work-item {
  color: var(--filter-txt);
  width: 25%;
  float: left;
  margin: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.work-item h2 {
    color: var(--filter-head);
}
.work-grid-2 .work-item {
  width: 49.99%;
}
.work-grid-3 .work-item {
  width: 33.333%;
}
.container .work-grid-3 .work-item {
  width: 33.2%;
}
.work-grid-5 .work-item {
  width: 20%;
}
.works-grid.work-grid-gut {
  margin: 0 0 0 -30px;
}
.works-grid.work-grid-gut .work-item {
  padding: 0 0 30px 30px;
}
.work-item > a {
  display: block;
  padding: 0 0 100px 0;
  position: relative;
  box-sizing: border-box;
  text-decoration: none;
}
.work-item a {
  text-decoration: none;
  border: none;
  color: var(--filter-hover);
}
.work-item a:hover {
  text-decoration: underline 1px solid var(--filter-hover);
  text-underline-offset: 4px;
  border: none;
}
.light-content .work-item a,
.light-content .work-item a:hover {
/*  color: var(--page-bg); */
}
.work-img {
  position: relative;
  overflow: hidden;
  -webkit-transform: rotate(0.0001deg) translateZ(0);
  transform: rotate(0.0001deg) translateZ(0);
}
.work-img-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #f5f5f5;
}
.light-content .work-img-bg {
  background-color: #282828;
}
.work-img img {
  display: block;
  position: relative;
  width: 100%;
  overflow: hidden;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.work-title {
  margin: 0 0 3px 0;
  padding: 0;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.2;
  text-transform: none;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.container .work-grid-4 .work-title,
.container .work-grid-5 .work-title {
  font-size: 18px;
}
.works-grid.hide-titles .work-item > a {
  overflow: hidden;
  padding: 0;
}
.work-item:hover .work-title {
/*  color: var(--page-bg); */
  -webkit-transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
  transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
}
.work-item .work-img:after {
  content: " ";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(250, 250, 250, 0);
  -webkit-transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
  transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
}
.work-item:hover .work-img:after {
  background: rgba(20, 20, 20, 0.85);
}
.works-grid.hover-white .work-item:hover .work-title {
/*  color: var(--body-text); */
}
.works-grid.hover-white .work-item:hover .work-img:after {
  background: rgba(250, 250, 250, 0.9);
}
.work-item .work-img > img {
  -webkit-transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
  transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
}
.work-item:hover .work-img > img {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}
.work-full {
  display: none;
  width: 100%;
  height: 100%;
  background: var(--page-bg);
  z-index: 10000;
}
.work-navigation {
  width: 100%;
  background: var(--page-bg);
  font-size: 16px;
  font-weight: 600;
  z-index: 99;
}
.work-navigation .fa {
  position: relative;
  top: 1px;
  font-size: 14px;
}
.work-navigation .fa-times {
  font-size: 16px;
  margin-top: -2px;
}
.work-navigation a {
  display: block;
  float: left;
  width: 33.33333%;
  overflow: hidden;
  vertical-align: middle;
  text-decoration: none;
  white-space: nowrap;
  cursor: default;
}
.work-navigation a,
.work-navigation a:visited {
/*  color: #757575; */
}
.work-navigation a:hover {
/*  color: #111; */
}
.work-navigation a span {
  display: inline-block;
  height: 80px;
  line-height: 79px;
  padding: 0 4%;
  background: var(--page-bg);
  cursor: pointer;
  -webkit-transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
  transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
}
.work-navigation span:hover {
  background: #f5f5f5;
}
.work-prev {
  text-align: left;
}
.work-all {
  text-align: center;
}
.work-next {
  text-align: right;
}
.work-container {
  padding: 50px 0;
}
.work-full-title {
  margin: 0 0 10px 0;
  padding: 0;
  font-size: 24px;
  font-weight: 700;
  text-transform: uppercase;
  text-align: center;
  letter-spacing: 1px;
}
.work-full-media {
  margin-top: 30px;
}
.work-full-media img {
  max-width: 100%;
  height: auto;
}
.work-full-text {
  text-align: left;
  font-size: 18px;
/*  color: #757575;  */
}
.work-detail p:last-child {
  margin-bottom: 0;
}
.work-full-detail {
  font-size: 15px;
/*  color: #757575;    */
}
.work-full-detail p {
  padding: 4px 0;
  margin: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.work-full-detail p:last-child {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.light-content .work-full-text {
/*  color: #bbb; */
}
.light-content .work-full-detail {
/*  color: #bbb; */
}
.light-content .work-full-detail p {
  border-color: rgba(255, 255, 255, 0.1);
}
.light-content .work-full-detail p:last-child {
  border-color: rgba(255, 255, 255, 0.1);
}
.work-navigation.light-content a,
.work-navigation.light-content a:visited {
/*  color: #bbb; */
}
.work-navigation.light-content a:hover {
 /* color: var(--page-bg);   */
}
.work-navigation.light-content a span {
  background-color: transparent;
}
.work-navigation.light-content span:hover {
  background-color: rgba(255, 255, 255, 0.05);
}
.tpl-tabs {
/*  border-color: #ccc; */
}
.tpl-tabs > li > a,
.tpl-tabs > li > a:hover {
/*  color: #757575; */
  text-decoration: none;
  line-height: 2.4;
}
.tpl-tabs li .nav-link.active {
  border-color: #ccc #ccc var(--page-bg);
}
.tpl-tabs-cont {
  padding: 30px 0;
  line-height: 1.8;
}
.light-content .tpl-tabs {
  border-color: #bbb;
}
.light-content .tpl-tabs > li > a {
/*  color: #ccc;  */
}
.light-content .tpl-tabs li .nav-link:hover {
  border-color: #333 #333 transparent;
/*  color: var(--page-bg);   */
}
.light-content .tpl-tabs li .nav-link.active {
  border-color: #bbb #bbb #1b1b1b;
  background-color: transparent;
/*  color: var(--page-bg);       */
}






/* ============================================
   TABBED CONTENT
   ============================================ */

/* --- Panel visibility & presence (logic + subtle transition) --- */
.tabs .tabs-content > [data-tab-panel] {
  display: none;
  opacity: 0;
}

.tabs .tabs-content > [data-tab-panel].is-active {
  display: block;
  opacity: 1;
  transition: opacity 0.25s ease;
}

/* --- Trigger layout --- */
.tabs .tabs-triggers {
  display: flex;
  gap: 2.5rem;
  margin-bottom: 1.5rem;
}

/* --- Trigger appearance (typographic, neutral) --- */
.tabs .tabs-triggers button {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-family: var(--font-medium);
  color: var(--luxe-text);
  position: relative;
}

/* Active trigger */
.tabs .tabs-triggers button.is-active {
  color: var(--luxe-accent);
}

/* Hover trigger */
.tabs .tabs-triggers button:hover {
  color: var(--luxe-accent);
}


/* --- Subtle active indicator (editorial underline) --- */
.tabs .tabs-triggers button::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 1px;
  background: var(--luxe-accent);
  opacity: 0;
  transition: opacity 0.2s ease;
}

.tabs .tabs-triggers button.is-active::after {
  opacity: 1;
}

/* --- Mobile handling: wrapped & centered --- */
@media (max-width: 1024px) {
  .tabs .tabs-triggers {
    flex-wrap: wrap;
    justify-content: left;
    gap: 1rem 0.7rem;
    margin-bottom: 1rem;
  }
}
@media (max-width: 768px) {
  .tabs .tabs-triggers {
    flex-wrap: wrap;
    justify-content: left;
    gap: 0.5rem 0.5rem;
    margin-bottom: 0.5rem;
  }
}


/* ============================================
   HERO – DESKTOP / LANDSCAPE
   ============================================ */

.home-hero {
    position: relative;
    width: 100%;
    height: 100vh;            /* full screen */
    overflow: hidden;
}
@media (orientation: portrait) and (max-width: 992px) {
    .home-hero {
        position: relative;
        width: 100%;
        height: 110vh;            /* full screen */
        overflow: hidden;
    }
}

/* ============================================================
   PRODUCT IMAGE – CENTERED, LARGE, HEIGHT-DRIVEN SCALING
   ============================================================ */

.hero-product-image {
    position: absolute;
    left: 50%;
    top: 48%;                      /* controls the vertical “lift” */
    transform: translate(-50%, -50%);
    height: 75vh;                  /* *** recommended baseline *** */
    width: auto;
    object-fit: cover;
    z-index: 2;
    pointer-events: none;
    padding: 5vw;
}
@media (orientation: portrait) and (max-width: 992px) {
    .hero-product-image {
            top: 33%;                      /* controls the vertical “lift” */
            transform: translate(-50%, -50%);
            height: 75vh;              /* *** recommended baseline *** */
    }
}
/* ============================================================
   TEXT – LOWER LEFT BAND
   ============================================================ */

.hero-content {
    position: absolute;
    left: 12vw;                     /* horizontal inset */
    top: 78vh;                     /* controls text vertical band */
    transform: translateY(-50%);  
    z-index: 3;
    max-width: 80vw;               /* adjust to your taste */
    text-align: left;
}










/* ================  SPACING  ========================= */

/* ------ Sets top of header-section to bottom of menu ------*/

.pt-menu {
    padding-top: var(--menu-height);
}
@media (max-width: 1024px) {
    .pt-menu {
        padding-top: 0px;
    }
}

/* ------- Padding Sets Gaps Inside The DIV --------*/

/* ------- Padding Based On Viewport Size --------*/

/* ------ Sets Minimal Padding ------*/

.pt {
  padding-top: 3vw;
}
.pb {
  padding-bottom: 3vw;
}
.pr {
    padding-right: 3vw;
}
.pl {
    padding-left: 3vw;
}

/* ------- Padding-Left Scaling With Viewport Width --------- */

.pl1 {
  padding-left: 1vw;
}
.pl2 {
  padding-left: 2vw;
}
.pl3 {
  padding-left: 3vw;
}
.pl4 {
  padding-left: 4vw;
}
.pl5 {
  padding-left: 5vw;
}
.pl6 {
  padding-left: 6vw;
}
.pl7 {
  padding-left: 7vw;
}
.pl8 {
  padding-left: 8vw;
}
.pl9 {
  padding-left: 9vw;
}
.pl10 {
  padding-left: 10vw;
}
.pl11 {
  padding-left: 11vw;
}
.pl12 {
  padding-left: 12vw;
}
.pl13 {
  padding-left: 13vw;
}
.pl14 {
  padding-left: 14vw;
}
.pl15 {
  padding-left: 15vw;
}
.pl16 {
  padding-left: 16vw;
}
.pl17 {
  padding-left: 17vw;
}
.pl18 {
  padding-left: 18vw;
}
.pl19 {
  padding-left: 19vw;
}
.pl20 {
  padding-left: 20vw;
}

/* ------- Padding-Right Scaling With Viewport Width --------- */


.pr1 {
    padding-right: 1vw;
}
.pr2 {
    padding-right: 2vw;
}
.pr3 {
    padding-right: 3vw;
}
.pr4 {
    padding-right: 4vw;
}
.pr5 {
    padding-right: 5vw;
}
.pr6 {
    padding-right: 6vw;
}
.pr7 {
    padding-right: 7vw;
}
.pr8 {
    padding-right: 8vw;
}
.pr9 {
    padding-right: 9vw;
}
.pr10 {
    padding-right: 10vw;
}
.pr11 {
    padding-right: 11vw;
}
.pr12 {
    padding-right: 12vw;
}
.pr13 {
    padding-right: 13vw;
}
.pr14 {
    padding-right: 14vw;
}
.pr15 {
    padding-right: 15vw;
}
.pr16 {
    padding-right: 16vw;
}
.pr17 {
    padding-right: 17vw;
}
.pr18 {
    padding-right: 18vw;
}
.pr19 {
    padding-right: 19vw;
}
.pr20 {
    padding-right: 20vw;
}

/* ------- Padding-Top Scaling With Viewport Height --------- */

.ptx {
    padding-top: 1px!important;
}
.pt0 {
    padding-top: 0.5vh!important;
}
.pt1 {
    padding-top: 1vh!important;
}
.pt2 {
    padding-top: 2vh!important;
}
.pt3 {
    padding-top: 3vh!important;
}
.pt4 {
    padding-top: 4vh!important;
}
.pt5 {
    padding-top: 5vh!important;
}
.pt6 {
    padding-top: 6vh!important;
}
.pt7 {
    padding-top: 7vh!important;
}
.pt8 {
    padding-top: 8vh!important;
}
.pt9 {
    padding-top: 9vh!important;
}
.pt10 {
    padding-top: 10vh!important;
}
.pt11 {
    padding-top: 11vh!important;
}
.pt12 {
    padding-top: 12vh!important;
}
.pt13 {
    padding-top: 13vh!important;
}
.pt14 {
    padding-top: 14vh!important;
}
.pt15 {
    padding-top: 15vh!important;
}
.pt16 {
    padding-top: 16vh!important;
}
.pt17 {
    padding-top: 17vh!important;
}
.pt18 {
    padding-top: 18vh!important;
}
.pt19 {
    padding-top: 19vh!important;
}
.pt20 {
    padding-top: 20vh!important;
}


/* ------- Padding-Bottom Scaling With Viewport Height --------- */

.pbx {
    padding-bottom: 1px!important;
}
.pb0 {
    padding-bottom: 0.5vh!important;
}
.pb1 {
    padding-bottom: 1vh!important;
}
.pb2 {
    padding-bottom: 2vh!important;
}
.pb3 {
    padding-bottom: 3vh!important;
}
.pb4 {
    padding-bottom: 4vh!important;
}
.pb5 {
    padding-bottom: 5vh!important;
}
.pb6 {
    padding-bottom: 6vh!important;
}
.pb7 {
    padding-bottom: 7vh!important;
}
.pb8 {
    padding-bottom: 8vh!important;
}
.pb9 {
    padding-bottom: 9vh!important;
}
.pb10 {
    padding-bottom: 10vh!important;
}
.pb11 {
    padding-bottom: 11vh!important;
}
.pb12 {
    padding-bottom: 12vh!important;
}
.pb13 {
    padding-bottom: 13vh!important;
}
.pb14 {
    padding-bottom: 14vh!important;
}
.pb15 {
    padding-bottom: 15vh!important;
}
.pb16 {
    padding-bottom: 16vh!important;
}
.pb17 {
    padding-bottom: 17vh!important;
}
.pb18 {
    padding-bottom: 18vh!important;
}
.pb19 {
    padding-bottom: 19vh!important;
}
.pb20 {
    padding-bottom: 20vh!important;
}

/* ------- Padding Based On Pixels --------*/

/* ------- Padding-Left --------- */

.pl-10 {
  padding-left: 10px !important;
}
.pl-20 {
  padding-left: 20px !important;
}
.pl-30 {
  padding-left: 30px !important;
}
.pl-40 {
  padding-left: 40px !important;
}
.pl-50 {
  padding-left: 50px !important;
}
.pl-60 {
  padding-left: 60px !important;
}
.pl-70 {
  padding-left: 70px !important;
}
.pl-80 {
  padding-left: 80px !important;
}
.pl-90 {
  padding-left: 90px !important;
}
.pl-100 {
  padding-left: 100px !important;
}
.pl-110 {
  padding-left: 110px !important;
}
.pl-120 {
  padding-left: 120px !important;
}
.pl-130 {
  padding-left: 130px !important;
}
.pl-140 {
  padding-left: 140px !important;
}
.pl-150 {
  padding-left: 150px !important;
}
.pl-160 {
  padding-left: 160px !important;
}
.pl-170 {
  padding-left: 170px !important;
}
.pl-180 {
  padding-left: 180px !important;
}
.pl-190 {
  padding-left: 190px !important;
}
.pl-200 {
  padding-left: 200px !important;
}

/* ------- Padding-Right --------- */

.pr-10 {
  padding-right: 10px !important;
}
.pr-20 {
  padding-right: 20px !important;
}
.pr-30 {
  padding-right: 30px !important;
}
.pr-40 {
  padding-right: 40px !important;
}
.pr-50 {
  padding-right: 50px !important;
}
.pr-60 {
  padding-right: 60px !important;
}
.pr-70 {
  padding-right: 70px !important;
}
.pr-80 {
  padding-right: 80px !important;
}
.pr-90 {
  padding-right: 90px !important;
}
.pr-100 {
  padding-right: 100px !important;
}
.pr-110 {
  padding-right: 110px !important;
}
.pr-120 {
  padding-right: 120px !important;
}
.pr-130 {
  padding-right: 130px !important;
}
.pr-140 {
  padding-right: 140px !important;
}
.pr-150 {
  padding-right: 150px !important;
}
.pr-160 {
  padding-right: 160px !important;
}
.pr-170 {
  padding-right: 170px !important;
}
.pr-180 {
  padding-right: 180px !important;
}
.pr-190 {
  padding-right: 190px !important;
}
.pr-200 {
  padding-right: 200px !important;
}

/* ------- Padding-Top --------- */

.pt-10 {
  padding-top: 10px !important;
}
.pt-20 {
  padding-top: 20px !important;
}
.pt-30 {
  padding-top: 30px !important;
}
.pt-40 {
  padding-top: 40px !important;
}
.pt-50 {
  padding-top: 50px !important;
}
.pt-60 {
  padding-top: 60px !important;
}
.pt-70 {
  padding-top: 70px !important;
}
.pt-80 {
  padding-top: 80px !important;
}
.pt-90 {
  padding-top: 90px !important;
}
.pt-100 {
  padding-top: 100px !important;
}
.pt-110 {
  padding-top: 110px !important;
}
.pt-120 {
  padding-top: 120px !important;
}
.pt-130 {
  padding-top: 130px !important;
}
.pt-140 {
  padding-top: 140px !important;
}
.pt-150 {
  padding-top: 150px !important;
}
.pt-160 {
  padding-top: 160px !important;
}
.pt-170 {
  padding-top: 170px !important;
}
.pt-180 {
  padding-top: 180px !important;
}
.pt-190 {
  padding-top: 190px !important;
}
.pt-200 {
  padding-top: 200px !important;
}


/* ------- Padding-Bottom --------- */

.pb-10 {
  padding-bottom: 10px !important;
}
.pb-20 {
  padding-bottom: 20px !important;
}
.pb-30 {
  padding-bottom: 30px !important;
}
.pb-40 {
  padding-bottom: 40px !important;
}
.pb-50 {
  padding-bottom: 50px !important;
}
.pb-60 {
  padding-bottom: 60px !important;
}
.pb-70 {
  padding-bottom: 70px !important;
}
.pb-80 {
  padding-bottom: 80px !important;
}
.pb-90 {
  padding-bottom: 90px !important;
}
.pb-100 {
  padding-bottom: 100px !important;
}
.pb-110 {
  padding-bottom: 110px !important;
}
.pb-120 {
  padding-bottom: 120px !important;
}
.pb-130 {
  padding-bottom: 130px !important;
}
.pb-140 {
  padding-bottom: 140px !important;
}
.pb-150 {
  padding-bottom: 150px !important;
}
.pb-160 {
  padding-bottom: 160px !important;
}
.pb-170 {
  padding-bottom: 170px !important;
}
.pb-180 {
  padding-bottom: 180px !important;
}
.pb-190 {
  padding-bottom: 190px !important;
}
.pb-200 {
  padding-bottom: 200px !important;
}


/* ------- Margin Sets Gaps Outside The DIV --------*/

/* ------- Margin Based On Viewport Size --------*/

/* ------ Sets Minimal Margin ------*/

.ml {
  margin-left: 3vw!important;
}
.mt {
  margin-top: 3vw!important;
}
.mb {
  margin-bottom: 3vw!important;
}
.mr {
    margin-right: 3vw!important;
}

/* ------- Margin-Left Scaling With Viewport Width --------- */

.ml0 {
  margin-left: 0.5vw!important;
}
.ml1 {
  margin-left: 1vw!important;
}
.ml2 {
  margin-left: 2vw!important;
}
.ml3 {
  margin-left: 3vw!important;
}
.ml4 {
  margin-left: 4vw!important;
}
.ml5 {
  margin-left: 5vw!important;
}
.ml6 {
  margin-left: 6vw!important;
}
.ml7 {
  margin-left: 7vw!important;
}
.ml8 {
  margin-left: 8vw!important;
}
.ml9 {
  margin-left: 9vw!important;
}
.ml10 {
  margin-left: 10vw!important;
}

/* ------- Margin-Right Scaling With Viewport Width --------- */


.mrx {
    margin-right: 1px!important;
}
.mr0 {
    margin-right: 0.5vw!important;
}
.mr1 {
    margin-right: 1vw!important;
}
.mr2 {
    margin-right: 2vw!important;
}
.mr3 {
    margin-right: 3vw!important;
}
.mr4 {
    margin-right: 4vw!important;
}
.mr5 {
    margin-right: 5vw!important;
}
.mr6 {
    margin-right: 6vw!important;
}
.mr7 {
    margin-right: 7vw!important;
}
.mr8 {
    margin-right: 8vw!important;
}
.mr9 {
    margin-right: 9vw!important;
}
.mr10 {
    margin-right: 10vw!important;
}

/* ------- Margin-Top Scaling With Viewport Height --------- */

.mtx {
    margin-top: 1px!important;
}
.mt0 {
    margin-top: 0.5vh!important;
}
.mt1 {
    margin-top: 1vh!important;
}
.mt2 {
    margin-top: 2vh!important;
}
.mt3 {
    margin-top: 3vh!important;
}
.mt4 {
    margin-top: 4vh!important;
}
.mt5 {
    margin-top: 5vh!important;
}
.mt6 {
    margin-top: 6vh!important;
}
.mt7 {
    margin-top: 7vh!important;
}
.mt8 {
    margin-top: 8vh!important;
}
.mt9 {
    margin-top: 9vh!important;
}
.mt10 {
    margin-top: 10vh!important;
}
.mt11 {
    margin-top: 11vh!important;
}
.mt12 {
    margin-top: 12vh!important;
}
.mt13 {
    margin-top: 13vh!important;
}
.mt14 {
    margin-top: 14vh!important;
}
.mt15 {
    margin-top: 15vh!important;
}
.mt16 {
    margin-top: 16vh!important;
}
.mt17 {
    margin-top: 17vh!important;
}
.mt18 {
    margin-top: 18vh!important;
}
.mt19 {
    margin-top: 19vh!important;
}
.mt20 {
    margin-top: 20vh!important;
}


/* ------- Margin-Bottom Scaling With Viewport Height --------- */

.mbx {
    margin-bottom: 1px!important;
}
.mb0 {
    margin-bottom: 0.5vh!important;
}
.mb1 {
    margin-bottom: 1vh!important;
}
.mb2 {
    margin-bottom: 2vh!important;
}
.mb3 {
    margin-bottom: 3vh!important;
}
.mb4 {
    margin-bottom: 4vh!important;
}
.mb5 {
    margin-bottom: 5vh!important;
}
.mb6 {
    margin-bottom: 6vh!important;
}
.mb7 {
    margin-bottom: 7vh!important;
}
.mb8 {
    margin-bottom: 8vh!important;
}
.mb9 {
    margin-bottom: 9vh!important;
}
.mb10 {
    margin-bottom: 10vh!important;
}
.mb11 {
    margin-bottom: 11vh!important;
}
.mb12 {
    margin-bottom: 12vh!important;
}
.mb13 {
    margin-bottom: 13vh!important;
}
.mb14 {
    margin-bottom: 14vh!important;
}
.mb15 {
    margin-bottom: 15vh!important;
}
.mb16 {
    margin-bottom: 16vh!important;
}
.mb17 {
    margin-bottom: 17vh!important;
}
.mb18 {
    margin-bottom: 18vh!important;
}
.mb19 {
    margin-bottom: 19vh!important;
}
.mb20 {
    margin-bottom: 20vh!important;
}

/* ------- Margin Based On Pixels --------*/

/* ------- Margin-Left --------- */

.ml-10 {
  margin-left: 10px !important;
}
.ml-20 {
  margin-left: 20px !important;
}
.ml-30 {
  margin-left: 30px !important;
}
.ml-40 {
  margin-left: 40px !important;
}
.ml-50 {
  margin-left: 50px !important;
}
.ml-60 {
  margin-left: 60px !important;
}
.ml-70 {
  margin-left: 70px !important;
}
.ml-80 {
  margin-left: 80px !important;
}
.ml-90 {
  margin-left: 90px !important;
}
.ml-100 {
  margin-left: 100px !important;
}
.ml-110 {
  margin-left: 110px !important;
}
.ml-120 {
  margin-left: 120px !important;
}
.ml-130 {
  margin-left: 130px !important;
}
.ml-140 {
  margin-left: 140px !important;
}
.ml-150 {
  margin-left: 150px !important;
}
.ml-160 {
  margin-left: 160px !important;
}
.ml-170 {
  margin-left: 170px !important;
}
.ml-180 {
  margin-left: 180px !important;
}
.ml-190 {
  margin-left: 190px !important;
}
.ml-200 {
  margin-left: 200px !important;
}

/* ------- Margin-Right --------- */

.mr-10 {
  margin-right: 10px !important;
}
.mr-20 {
  margin-right: 20px !important;
}
.mr-30 {
  margin-right: 30px !important;
}
.mr-40 {
  margin-right: 40px !important;
}
.mr-50 {
  margin-right: 50px !important;
}
.mr-60 {
  margin-right: 60px !important;
}
.mr-70 {
  margin-right: 70px !important;
}
.mr-80 {
  margin-right: 80px !important;
}
.mr-90 {
  margin-right: 90px !important;
}
.mr-100 {
  margin-right: 100px !important;
}
.mr-110 {
  margin-right: 110px !important;
}
.mr-120 {
  margin-right: 120px !important;
}
.mr-130 {
  margin-right: 130px !important;
}
.mr-140 {
  margin-right: 140px !important;
}
.mr-150 {
  margin-right: 150px !important;
}
.mr-160 {
  margin-right: 160px !important;
}
.mr-170 {
  margin-right: 170px !important;
}
.mr-180 {
  margin-right: 180px !important;
}
.mr-190 {
  margin-right: 190px !important;
}
.mr-200 {
  margin-right: 200px !important;
}

/* ------- Margin-Top --------- */

.mt-5 {
  margin-top: 5px !important;
}
.mt-6 {
  margin-top: 6px !important;
}
.mt-10 {
  margin-top: 10px !important;
}
.mt-20 {
  margin-top: 20px !important;
}
.mt-30 {
  margin-top: 30px !important;
}
.mt-40 {
  margin-top: 40px !important;
}
.mt-50 {
  margin-top: 50px !important;
}
.mt-60 {
  margin-top: 60px !important;
}
.mt-70 {
  margin-top: 70px !important;
}
.mt-80 {
  margin-top: 80px !important;
}
.mt-90 {
  margin-top: 90px !important;
}
.mt-100 {
  margin-top: 100px !important;
}
.mt-110 {
  margin-top: 110px !important;
}
.mt-120 {
  margin-top: 120px !important;
}
.mt-130 {
  margin-top: 130px !important;
}
.mt-140 {
  margin-top: 140px !important;
}
.mt-150 {
  margin-top: 150px !important;
}
.mt-160 {
  margin-top: 160px !important;
}
.mt-170 {
  margin-top: 170px !important;
}
.mt-180 {
  margin-top: 180px !important;
}
.mt-190 {
  margin-top: 190px !important;
}
.mt-200 {
  margin-top: 200px !important;
}


/* ------- Margin-Bottom --------- */

.mb-10 {
  margin-bottom: 10px !important;
}
.mb-20 {
  margin-bottom: 20px !important;
}
.mb-30 {
  margin-bottom: 30px !important;
}
.mb-40 {
  margin-bottom: 40px !important;
}
.mb-50 {
  margin-bottom: 50px !important;
}
.mb-60 {
  margin-bottom: 60px !important;
}
.mb-70 {
  margin-bottom: 70px !important;
}
.mb-80 {
  margin-bottom: 80px !important;
}
.mb-90 {
  margin-bottom: 90px !important;
}
.mb-100 {
  margin-bottom: 100px !important;
}
.mb-110 {
  margin-bottom: 110px !important;
}
.mb-120 {
  margin-bottom: 120px !important;
}
.mb-130 {
  margin-bottom: 130px !important;
}
.mb-140 {
  margin-bottom: 140px !important;
}
.mb-150 {
  margin-bottom: 150px !important;
}
.mb-160 {
  margin-bottom: 160px !important;
}
.mb-170 {
  margin-bottom: 170px !important;
}
.mb-180 {
  margin-bottom: 180px !important;
}
.mb-190 {
  margin-bottom: 190px !important;
}
.mb-200 {
  margin-bottom: 200px !important;
}

/* -----------Arrange Items Within Container ------------ */

/* ----- Items are positioned at the beginning of the container ----- */
.justify-start {
  justify-content: flex-start;
}

/* ----- Items are positioned at the end of the container ----- */
.justify-end {
  justify-content: flex-end;
}

/* ----- Items are positioned in the center of the container ----- */
.justify-center {
  justify-content: center;
}

/* ----- Items will have space between them ----- */
.justify-space-between {
  justify-content: space-between;
}

/* ----- Items will have space before, between, and after them ----- */
.justify-space-around {
  justify-content: space-around;
}

/* ----- Items will have equal space around them ----- */
.justify-space-evenly {
  justify-content: space-evenly;
}










/* ================== CENTERING ==================== */


.mx-auto {
    margin-right:auto!important;
    margin-left:auto!important
}
.my-auto {
  margin-top: auto !important;
  margin-bottom: auto !important;
}
.vertical-center-div {
  margin: 0;
  position: absolute;
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
}
.vertical-center {
  margin: 0;
  position: absolute;
  top: 50%;
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
}
.center-both {
  display: flex;
  justify-content: center;
  align-items: center;
  height: auto;
}
.min-height-80vh {
  min-height: 80vh;
}
.min-height-90vh {
  min-height: 90vh;
}
.min-height-100vh {
  min-height: 100vh;
  min-height: calc(var(--vh, 1vh) * 100);
}




/* ================= ALIGNMENT  ================== */

.align-center {
  text-align: center !important;
}
.align-left {
  text-align: left !important;
}
.align-right {
  text-align: right !important;
}
.align-footer-image {
  text-align: left !important;
}
 @media (max-width: 1024px) {
     .align-footer-image {
        text-align: center !important;
     }
}
.left {
  float: left !important;
}
.right {
  float: right !important;
}
.align-vertical {
    display: flex;
    justify-content: center;
    flex-direction: column;
}


/* =====  SOFT BREAK ============== */

.conditional-break {
    display: inline;
}

.conditional-break.is-active {
    display: block;
    height: 0;
}

/* =====  TEXT WRAP COLUMNS ============== */

.two-cols {
    column-count: 1;
    column-gap: 40px;
}

/* Desktop and larger */
@media (min-width: 1025px) {
    .two-cols {
        column-count: 2;
        column-fill: balance;
    }
}

/* Prevent awkward breaks inside paragraphs */
.two-cols p {
    break-inside: avoid;
    margin-top: 0;
}


/* ===============  PAGE LOADER ================= */

.page-loader {
  display: block;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background: #fefefe;
  z-index: 100000;
}
.loader {
  width: 50px;
  height: 50px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -25px 0 0 -25px;
  font-size: 10px;
  text-indent: -12345px;
  border-top: 1px solid rgba(0, 0, 0, 0.15);
  border-right: 1px solid rgba(0, 0, 0, 0.15);
  border-bottom: 1px solid rgba(0, 0, 0, 0.15);
  border-left: 1px solid rgba(0, 0, 0, 0.55);
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
  -webkit-animation: spinner 0.7s infinite linear;
  -moz-animation: spinner 0.7s infinite linear;
  -ms-animation: spinner 0.7s infinite linear;
  -o-animation: spinner 0.7s infinite linear;
  animation: spinner 0.7s infinite linear;
  will-change: transform;
  z-index: 100001;
}
.page-loader.dark {
  background: #111;
}
.page-loader.dark .loader {
  background: #111;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  border-right: 1px solid rgba(255, 255, 255, 0.15);
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  border-left: 1px solid rgba(255, 255, 255, 0.5);
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
  -webkit-animation: spinner 0.7s infinite linear;
  -moz-animation: spinner 0.7s infinite linear;
  animation: spinner 0.7s infinite linear;
  z-index: 100001;
}
@-webkit-keyframes spinner {
  0% {
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@-moz-keyframes spinner {
  0% {
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes spinner {
  0% {
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
#loading {
  background: url(https://camerata.app/theme/antipodes/images/spin1.gif) no-repeat
    center center;
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 9999999;
}
#loading-word {
  text-align: center;
  font-size: 20px;
  margin-top: 50px;
}







/* ==================  SKIP TO CONTENT  ============================  */

.skip-to-content {
  position: absolute;
  top: 3px;
  left: 3px;
  padding: 20px 40px;
/*  color: var(--page-bg);      */
  background: #111;
  -webkit-transform: translateY(-150%);
  -moz-transform: translateY(-150%);
  transform: translateY(-150%);
  z-index: 100000;
}
.skip-to-content:focus,
.skip-to-content:hover {
/*  color: var(--page-bg);      */
  opacity: 1;
  background: var(--body-text);
  -webkit-transform: translateY(0);
  -moz-transform: translateY(0);
  transform: translateY(0);
}







/* ==============================  Small Screens  ============================== */


@media screen and (min-width: 1366px) {
    .item-list {
        display: flex;
        flex-wrap: wrap;
    }

    .item-list li {
        width: 50%;
        box-sizing: border-box;
    }

    /* Ensure that the first item takes the full width */
    .item-list li:first-child {
        width: 100%;
    }
}

   
@media only screen and (max-width: 1366px) {	
    
    .full-wrapper{
        margin-left: 30px;
        margin-right: 30px;
    }    
    .inner-nav ul li{
        margin-left: 10px;
    }
    .mn-has-multi {
        width: 41vw !important;
        padding: 5px;
        max-width: 41vw;
        margin: 0 30vw 0 30vw !important;
    }
    .mn-sub-multi {
        width: 98vw !important;
    }
    .cols4 {
        width: 180px !important;
    }
    .rows41 {
        min-width: 80vw !important;
        margin: 0 10vw 0 10vw !important;
        height: auto !important;
        overflow: hidden !important;
    }
    .inner-nav ul li .mn-sub li a{
        padding: 8px 8px;
    }
    .text-over {
        padding-bottom: 30vh;
    }
    .rows {
      display: flex;
    }
    .xcolumn {
      width: 100%;
    }
    .item-list {
        display: flex;
        flex-direction: column;
    }    
}

@media only screen and (max-width: 1200px) {
    
    .inner-nav ul li{
        margin-left: 10px;
    }
    .form input[type="text"].input-lg,
    .form input[type="email"].input-lg,
    .form input[type="number"].input-lg,
    .form input[type="url"].input-lg,
    .form input[type="search"].input-lg,
    .form input[type="tel"].input-lg,
    .form input[type="password"].input-lg,
    .form input[type="date"].input-lg,
    .form input[type="color"].input-lg,
    .form select.input-lg{
        height: 51px;
    }
    .btn-mod.btn-large{
        padding: 12px 35px 14px;
    }
    .alt-service-grid{
        margin-top: -40px;
    } 
    .alt-service-item{
        margin-top: 40px;
        padding-left: 48px;
    }
    .alt-services-title{
        margin-bottom: 5px;
    }
    .alt-services-image{
        margin-top: 10px;
    }
    
    .work-grid-4 .work-item{
        width: 20%;
    }

    .work-grid-5 .work-item{
        width: 25%;
    }
    
    .mod-breadcrumbs-mini{
        text-align: right;
    }
    .text-over {
        padding-bottom: 30vh;
    }
}
@media only screen and (max-width: 1199px) {
    
    .work-title{
        letter-spacing: 0;
    }
    .tpl-alt-tabs{
        letter-spacing: 0.2em;
    }
    .tpl-alt-tabs > li{
        width: 170px;
    }
    
    .split-section-wrapper{
        padding: 0 50px;
    }
    .text-over {
        padding-bottom: 30vh;
    }
}
/* ==============================
   Tablet landscape
   ============================== */

@media only screen and (max-width: 1024px) {
    
    .header {
        padding-top: 80px;
        padding-left: 30px;
    }
    .header-sub {
        padding-left: 30px;
    }
    .main-nav,
    .main-nav.small-height,
    .nav-logo-wrap .logo,
    .nav-logo-wrap .logo.small-height,
    .pad-top {
        padding-top: 1px;
    }
    .inner-nav ul li .mn-sub li a{
        padding: 8px 8px;
        color: var(--mob-txt-menu);
    }
    .mobile-cart,
    .mobile-cart.small-height,
    .mobile-nav,
    .mobile-nav.small-height{
        height: 58px !important;
        line-height: 48px !important;
    }
    .scroll-down-alt{
        width: 62px;
        height: 62px;
        line-height: 52px;
        margin-left: -31px;
    }
    .float-images-1{
        top: 12.8vw;
    }
    .team-item-wrap{
        padding: 52px 36px 15px 36px;
    }
    .benefit-item{
        width: 300px;
        padding: 15px 32px;
    }

    .page-section{
        padding: 60px 0;
        
    }
    .page-section, .home-section, .small-section{
        background-attachment: scroll;
    }
    
    .owl-pagination{
        bottom: 25px;
    }  
    
    .lp-item{
        width: 50%;
    }
    .lp-item:nth-child(4n + 5) { 
        clear: none; 
    }
    .lp-item:nth-child(2n + 3) {        
        clear:left;
    }
    .fa-examples > li{
        width: 33.3%;
    }
    .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 30vh;
    }
    .show-on-mobile {
        display: block!important;
    }
    .hide-on-mobile {
        display: none!important;
    }
}
  
@media only screen and (max-width: 992px) {
    
    .split-background{
        width: 32%;
    }    
    .owl-prev,
    .owl-next{
        height: 37px;
    }
    .owl-prev{
        left: 10px;
    }
    .owl-next{
        right: 10px;
    }
    .mod-breadcrumbs:not(.align-center):not(.mod-breadcrumbs-mini) {
        text-align: left !important;
    }
    
    .tpl-alt-tabs > li{
        width: 200px;
    }
      
    .split-section-headings,
    .split-section-headings.left,
    .split-section-headings.right,
    .split-section-content,
    .split-section-content.left,
    .split-section-content.right{
        float: none !important;
        width: auto;
    }
    
    .split-section-headings .section-title{
        letter-spacing: 5px;
    }
    
    .banner-text{
        text-align: center;
    } 
    
    .banner-image{
        margin: 40px 0;
    }
    .team-item-wrap{
        padding: 52px 10px 15px 10px;
    }
    .alt-features-grid{
        margin-top: -30px;
        margin-bottom: 30px;
    } 
    .alt-features-item{
        margin-top: 30px;
    }
    .work-item,
    .work-grid-2 .work-item,
    .work-grid-3 .work-item,
    .work-grid-4 .work-item,
    .container .work-grid-3 .work-item,
    .container .work-grid-4 .work-item,
    .work-grid-5 .work-item{
        width: 49.9%;
    }      
    .countdown > li{
        margin: 0 20px;
    }
    .countdown-number{
        width: 74px;
        height: 74px;
/*        font-size: 24px;  */
        line-height: 64px;
    }
    .countdown-number > b{
        bottom: 18px;
    }   
    .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 30vh;
    }
    .hide-on-mobile {
        display: none!important;
    }
    .show-on-mobile {
        display: block!important;
    }

}
  
  
/* ==============================
   Tablet Portrait
   ============================== */
  
@media only screen and (max-width: 768px) {

    .hs-wrap{
        max-width: 400px;
    }
    .float-images-1{;
        top: 27vw;
        width: 18vw;
    }
    .float-images-2{;
        width: 18vw;
    }
    .float-images-3{
        bottom: 29.5vh;
        width: 13vw;
    }
    .float-images-4{;
        bottom: 15vh;
        width: 18vw;
    }
    .page-section{
        padding: 40px 0;
    }    
    .small-section{
        padding: 30px 0;
    }

    .owl-pagination{
        bottom: 17px;
    }  
    
    .tpl-minimal-tabs > li{
        padding: 0 5px;
    }    
        
    .benefit-item{
        width: 264px;
    }
    .alt-service-grid{
        margin-top: -30px;
    }
    .alt-service-item{
        margin-top: 30px;
    }

    .works-filter a{
        margin: 4px;
    }    
    .blog-item{
        margin-bottom: 50px;
    }
    .blog-media{
        margin-bottom: 15px;
    }
    .google-map > iframe{
        height: 300px;
    }    
    .fm-logo-wrap{
        top: 17px;
        left: 17px;
    }
    .fm-button{
        top: 17px;
        right: 17px;
    }
    .link-to-top {
        display: none;
    }
    .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 30vh;
    }
}

@media only screen and (max-width: 767px) {
    
    .nav-logo-wrap .logo{
        max-width: 150px;
    }    
    .fixed-height-small{
        height: 300px;
        min-height: 300px;
    }
    .fixed-height-medium{
        height: 350px;
        min-height: 350px;
    }
    .fixed-height-large{
        height: 400px;
        min-height: 400px;
    }
    .hs-wrap{
        max-width: 320px;
        padding-top: 27px;
        padding-bottom: 33px;
    }
    .hs-image{
        display: none;
    }
    
    .hs-wrap-1{
        max-width: 240px;
    }    
    .team-item{
        max-width: 370px;
        margin-left: auto;
        margin-right: auto;
    }
    .benefit-item{
        width: 230px;
        padding: 0;
    }    
    .benefit-item:hover:after{
        display: none;
    }       
    .wide-heading{
     /*   font-size: 32px;  */
        letter-spacing: 2px;
    }    
    .works-filter a{
        margin: 4px;
        width: 46%;
    }
    .works-filter a.active:after,
    .works-filter a:hover:after{
        transform: scaleX(0);
        text-decoration: underline 2px solid var(--accent-40) !important;
        text-underline-offset: 3px !important;
    }
    .works-filter a.active,
    .works-filter a.active:hover,
    .works-filter a:hover{
        text-decoration: underline 2px solid var(--accent-40) !important;
        text-underline-offset: 3px !important;
    }
    .work-item,
    .work-grid-2 .work-item,
    .work-grid-3 .work-item,
    .work-grid-4 .work-item,
    .container .work-grid-3 .work-item,
    .container .work-grid-4 .work-item,
    .work-grid-5 .work-item{
        width: 50%;
    }   
    .newsletter-label-text{
        margin-top: 20px;
    }    
    blockquote footer{
        margin-top: 0;
    }
    .banner-content{
        text-align: center;
    } 
    .banner-image{
        text-align: center;
    }    
    .cf-left-col,
    .cf-right-col{
        width: auto;
        margin-right: 0;
        float: none;
    }    
    .section-more,
    .section-more.left,
    .section-more.right{
        float: none !important;
    }    
    .big-icon{
        width: 60px;
        height: 60px;
        line-height: 52px;
        margin-bottom: 0;
    }
    .blog-slide-info{
        padding: 10px;
    }
    .blog-slide-data{
        display: none;
    }    
    .top-bar{
        min-height: 0;
    }
    .top-links{
        float: none !important;
        padding: 5px 0;
        text-align: center;
    }
    .top-links li,
    .top-links li:last-child{
        float: none;
        border:none;
        display: inline-block;
    }
    .top-links li a{
        display: inline-block;
        min-width: 0;
        height: auto;
        line-height: 1;
        padding: 0 5px;
    }
    .top-links li a:hover,
    .top-bar.dark .top-links li a:hover{
        background: none;
    }    
    .side-panel{
        padding-bottom: 20px;
    }
    .sp-logo-wrap{
        max-width: 100px;
        margin: 0 auto;
    }
    .sp-logo-wrap .logo{
        padding: 20px 0 0 0;
    }
    .sp-menu-links a{
        padding-top: 10px;
        padding-bottom: 10px;
    }
    .sp-social-links{
        width: auto;
        position: static;
        padding-bottom: 10px;
    }    
    .countdown > li{
        margin: 0 10px 20px;
    }
    .countdown-number{
        width: 44px;
        height: 44px;
        font-size: 20px;
        line-height: 44px;
    }
    .countdown-number > b{
        bottom: -20px;
/*        color: rgba(255,255,255, .85);    */
    } 
    .text-mobile{
        line-height: 1.2;
    }
    .link-to-top {
        display: none;
    }
    .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 30vh;
    }
}


/* ==============================
   Phone
   ============================== */
  
@media only screen and (max-width: 575px) { 
    .form input.newsletter-field {
        display: block;
        width: 100%;
        margin-right: 0;
        margin-bottom: 10px;
    }
    .form .newsletter-button {
        display: block;
        width: 100%;
    }
    .link-to-top {
        display: none;
    }
    .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 25vh;
    }
}
    
@media only screen and (max-width: 480px) {
    
    .full-wrapper{
        margin-left: 1px;
        margin-right: 1px;
    }
/*    .container {
        padding-left: 1px;
        padding-right: 1px;
    } */
    .float-images-1{;
        top: 32vw;
        left: 7vw;
        width: 25vw;
    }
    .float-images-2{;
        width: 25vw;
    }
    .float-images-3{
        bottom: 22vh;
        right: 17vw;
        width: 18vw;
    }
    .float-images-4{;
        bottom: 8vh;
        width: 25vw;
    }
    blockquote{
        margin-bottom: 2em;
    }
    .blog-item-body blockquote p:before{
        display: block;
        margin-top: 1em;
        position: static;
        top: 0;
        left: 0;
        line-height: 0;
        opacity: 1;
    }
    .call-action-1-heading{
        font-size: 32px;
    }
    .form input[type="text"].input-md,
    .form input[type="email"].input-md,
    .form input[type="number"].input-md,
    .form input[type="url"].input-md,
    .form input[type="search"].input-md,
    .form input[type="tel"].input-md,
    .form input[type="password"].input-md,
    .form input[type="date"].input-md,
    .form input[type="color"].input-md,
    .form select.input-md,
    .form input[type="text"].input-lg,
    .form input[type="email"].input-lg,
    .form input[type="number"].input-lg,
    .form input[type="url"].input-lg,
    .form input[type="search"].input-lg,
    .form input[type="tel"].input-lg,
    .form input[type="password"].input-lg,
    .form input[type="date"].input-lg,
    .form input[type="color"].input-lg,
    .form select.input-lg{
        height: 41px;
        padding-bottom: 3px;
    }
    .form textarea.input-md,
    .form textarea.input-lg{
        padding-top: 6px;
        padding-bottom: 6px;
        font-size: var(--p2);
        line-height: var(--p2l);
    }
    .btn-mod.btn-medium,
    .btn-mod.btn-large{
        padding: 8px 15px 10px 15px;
    }
    .nav-bar-compact{
        top: 0;
        left: 0;
    }    
    .page-section{
        padding: 30px 0;
    }
    .small-section{
        padding: 20px 0;
    }    
    .owl-pagination{
        bottom: 5px !important;
    }    
    .owl-prev, .owl-next{
        display: none;
    }
    .owl-page{
        padding-left: 8px;
        padding-right: 8px;
    }    

    .tpl-minimal-tabs > li{
        padding: 0;
    }
    .tpl-minimal-tabs > li > a{
        padding: 6px 10px 5px;
    }
    .tpl-alt-tabs{
        letter-spacing: 0.1em;
    }
    .tpl-alt-tabs > li{
        width: 120px;
    }
    .work-container{
        padding: 30px 0;
    }     
    .works-filter{
        margin-bottom: 30px;
    }
    .works-filter a{
        width: 100%;
        margin-left: 0;
        margin-right: 0;
    }    
    .work-full-text{
        margin-top: 30px;
    }
    .call-action-2-image-2{
        margin: 60px auto;
    }
    .footer-social-links a{
        width: 42px;
        height: 42px;
        line-height: 42px !important;
    }
    .footer-social-links a i,
    .footer-social-links a span[class^=icon]{
        line-height: 42px;
    }
    .blog-container{
        margin-top: 30px;
        margin-bottom: 30px;
    }    
    .pagination a{
        min-width: 32px;
        margin-right: 3px;
        padding: 6px 8px;
    }
    .comment-avatar{
        width: 30px;
        margin-top: 7px;
    }    
    .separ-space{
        display: block;
        height: 10px;
    }    
    .google-map > iframe{
        height: 300px;
    }
    .tpl-tabs > li{
        display: block;
        float: none;
        width: 100%;
    }
    .tpl-tabs > li.active a{
        background: #f5f5f5 !important;
    }    
    .fm-search{
        width: 200px;
    }
    
    .fa-examples > li{
        width: 50%;
    }
    .shopping-cart-table-title{
        min-width: 150px; 
    }
    .link-to-top {
        display: none;
    }
    .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 25vh;
    }
    .hide-on-small {
        display: none!important;
    }
    .show-on-small {
        display: block!important;
    }
}


/* ==============================
   Small Phone
   ============================== 
  
@media only screen and (max-width: 379px) {
    
    .mobile-logo {
        opacity: 0!important;
    }
}*/


/* ==============================
   Very Small Phone
   ============================== */
  
@media only screen and (max-width: 319px) {
    
      .nav-social-links{
          display: none;
      }
    .link-to-top {
        display: none;
    }
    .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 25vh;
    }
/*    .mobile-logo {
        opacity: 0!important;
    } */
}


/* ==============================
   Max Height 767
   ============================== */

@media only screen and (max-height: 767px) {
    
    .split-image img{
        width: 100%;
    }
    .sp-social-links{
        padding-bottom: 10px;
        position: static;
        width: auto;
    }
    .text-over {
        padding-bottom: 25vh;
    }
    
}


/* ==============================
   Max Height 480
   ============================== */

@media only screen and (max-height: 480px) {
    
    .float-images-1{;
        top: 13.3vw;
        left: 7vw;
        width: 12vw;
    }
    .float-images-2{;
        width: 12vw;
    }
    .float-images-3{
        bottom: 29vh;
        right: 9.8vw;
        width: 9vw;
    }
    .float-images-4{;
        bottom: 8vh;
        width: 12vw;
    }
   .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 20vh;
    }
    
}


/* ==============================
   Max Height 374
   ============================== */

@media only screen and (max-height: 374px) {
    
    .min-height-80vh,
    .min-height-90vh,
    .min-height-100vh{
        min-height: 374px;
    }
    .img-lg {
        display: none;
    }
    .img-sm {
        display: block;
    }
    .text-over {
        padding-bottom: 15vh;
    }
    
}


/* ==============================
   IOS Background Fix
   ============================== */
  
.mobile .page-section, .mobile .home-section, .mobile .small-section{
    background-attachment: scroll;
}

/*
 * iPad Pro
 */

@media only screen and (min-width: 1025px) and (max-height: 1366px) and (-webkit-min-device-pixel-ratio: 1.5) {
    
    html:not(.no-touch) .page-section, html:not(.no-touch) .home-section, html:not(.no-touch) .small-section{
        background-attachment: scroll;
    }
    .float-images-1{
        top: 27vw;
        left: 10vw;
        width: 20vw;
    }
    .float-images-2{
        position: absolute;
        bottom: 0;
        left: 3.125vw;
        width: 20vw;
    }
    .float-images-3{
        bottom: 32vh;
        right: 14vw;
        width: 15vw;
    }
    .float-images-4{
        position: absolute;
        bottom: 18vh;
        right: 3.125vw;
        width: 20vw;
    }
}

/* ==============================
   Internet Explorer Fix
   ============================== */
@media all and (-ms-high-contrast:none){
     
    .min-height-80vh{
        height: 80vh;
    } 
    .min-height-90vh{
        height: 90vh;
    } 
    .min-height-100vh{
        height: 100vh;
    }
    .fixed-height-large{
        height: 800px;
    } 
    .fixed-height-medium{
        height: 700px;
    } 
    .fixed-height-small{
        height: 600px;
    }
     
}


/* ==============================
   Print Styles Fix
   ============================== */
  
@media print {
    
    *{
/*        color: var(--dark-bg) !important;         */
    }
    
    .main-nav{
        display: none;
    }
    .buy-button{
        display: none;
    }
    img{
        display: block;
    }    
}

